Bölüm 2: Hello'yu nf-core için yeniden yazma¶
Yapay Zeka Destekli Çeviri - daha fazla bilgi ve iyileştirme önerileri
Bu Hello nf-core eğitim kursunun ikinci bölümünde, Hello Nextflow başlangıç kursu tarafından üretilen pipeline'ın nf-core uyumlu bir versiyonunu nasıl oluşturacağınızı gösteriyoruz.
Eğitimin ilk bölümünde nf-core pipeline'larının çok sayıda yardımcı dosya ile oldukça detaylı bir yapıyı takip ettiğini fark etmişsinizdir. Tüm bunları sıfırdan oluşturmak çok yorucu olurdu, bu yüzden nf-core topluluğu, süreci başlatmak için bunun yerine bir şablondan yapılmasını sağlayan araçlar geliştirmiştir.
Bu araçları kullanarak bir pipeline iskeleti oluşturmayı, ardından mevcut 'normal' pipeline kodunu nf-core iskeleti üzerine nasıl uyarlayacağınızı göstereceğiz.
Eğer Hello pipeline'ına aşina değilseniz veya hatırlatmaya ihtiyacınız varsa, bu bilgi sayfasına bakın.
1. Yeni bir pipeline projesi oluşturma¶
İlk olarak, yeni pipeline için iskeleyi oluşturuyoruz.
Note
Terminalinizde hello-nf-core dizininde olduğunuzdan emin olun.
1.1. Şablon tabanlı pipeline oluşturma aracını çalıştırma¶
Yeni bir pipeline oluşturmak için nf-core pipelines create komutu ile başlayalım.
Bu, nf-core temel şablonunu kullanarak, bir pipeline adı, açıklaması ve yazarı ile özelleştirilmiş yeni bir pipeline iskeleti oluşturacaktır.
Bu komutu çalıştırmak, pipeline oluşturma için bir Metin Kullanıcı Arayüzü (TUI) açacaktır:
Bu TUI, pipeline'ınız hakkında temel bilgiler sağlamanızı isteyecek ve pipeline iskelenize dahil edilecek veya hariç tutulacak özellikler seçeneği sunacaktır.
- Hoş geldiniz ekranında Let's go! butonuna tıklayın.
Choose pipeline typeekranında Custom'a tıklayın.- Pipeline bilgilerinizi aşağıdaki gibi girin (
< YOUR NAME >kısmını kendi adınızla değiştirerek), ardından Next'e tıklayın.
[ ] GitHub organisation: core
[ ] Workflow name: hello
[ ] A short description of your pipeline: A basic nf-core style version of Hello Nextflow
[ ] Name of the main author(s): < YOUR NAME >
- Template features ekranında,
Toggle all features'ı kapalı olarak ayarlayın, ardından aşağıdakileri seçerek etkinleştirin. Seçimlerinizi kontrol edin ve Continue'ye tıklayın.
[ ] Add testing profiles
[ ] Use nf-core components
[ ] Use nf-schema
[ ] Add configuration files
[ ] Add documentation
Final detailsekranında Finish'e tıklayın. Pipeline'ın oluşturulmasını bekleyin, ardından Continue'ye tıklayın.- Create GitHub repository ekranında Finish without creating a repo'ya tıklayın. Bu, daha sonra bir GitHub repository'si oluşturmak için talimatları görüntüleyecektir. Bunları görmezden gelin ve Close'a tıklayın.
TUI kapandığında, aşağıdaki konsol çıktısını görmelisiniz.
Komut çıktısı
Pipeline oluşturmanın çalıştığına dair konsol çıktısında açık bir onay yoktur, ancak core-hello adında yeni bir dizin görmelisiniz.
Şablonu kullanarak kendinize ne kadar iş kazandırdığınızı görmek için yeni dizinin içeriğini görüntüleyin.
Dizin içeriği
core-hello/
├── assets
│ ├── samplesheet.csv
│ └── schema_input.json
├── conf
│ ├── base.config
│ ├── modules.config
│ ├── test.config
│ └── test_full.config
├── docs
│ ├── output.md
│ ├── README.md
│ └── usage.md
├── main.nf
├── modules.json
├── nextflow.config
├── nextflow_schema.json
├── README.md
├── subworkflows
│ ├── local
│ │ └── utils_nfcore_hello_pipeline
│ │ └── main.nf
│ └── nf-core
│ ├── utils_nextflow_pipeline
│ │ ├── main.nf
│ │ ├── meta.yml
│ │ └── tests
│ │ ├── main.function.nf.test
│ │ ├── main.function.nf.test.snap
│ │ ├── main.workflow.nf.test
│ │ └── nextflow.config
│ ├── utils_nfcore_pipeline
│ │ ├── main.nf
│ │ ├── meta.yml
│ │ └── tests
│ │ ├── main.function.nf.test
│ │ ├── main.function.nf.test.snap
│ │ ├── main.workflow.nf.test
│ │ ├── main.workflow.nf.test.snap
│ │ └── nextflow.config
│ └── utils_nfschema_plugin
│ ├── main.nf
│ ├── meta.yml
│ └── tests
│ ├── main.nf.test
│ ├── nextflow.config
│ └── nextflow_schema.json
└── workflows
└── hello.nf
14 directories, 34 files
Bu çok fazla dosya!
Umarız bunların çoğunu nf-core/demo pipeline yapısını incelediğimizde karşılaştığımız dosyalarla aynı olarak tanırsınız.
Ancak hala biraz kaybolmuş hissediyorsanız endişelenmeyin; bu eğitim boyunca önemli kısımları birlikte inceleyeceğiz.
Note
Bu eğitimin ilk bölümünde incelediğimiz nf-core/demo pipeline'ına kıyasla önemli bir fark, modules dizininin olmamasıdır.
Bunun nedeni, varsayılan nf-core modüllerinden herhangi birini dahil etmeyi seçmemiş olmamızdır.
1.2. İskeletin işlevsel olduğunu test etme¶
İnanın ya da inanmayın, gerçek iş yapmak için henüz herhangi bir modül eklememiş olsanız bile, pipeline iskeleti aslında test profilini kullanarak çalıştırılabilir, tıpkı nf-core/demo pipeline'ını çalıştırdığımız gibi.
Komut çıktısı
N E X T F L O W ~ version 25.04.3
Launching `./core-hello/main.nf` [scruffy_marconi] DSL2 - revision: b9e9b3b8de
Downloading plugin nf-schema@2.5.1
Input/output options
input : https://raw.githubusercontent.com/nf-core/test-datasets/viralrecon/samplesheet/samplesheet_test_illumina_amplicon.csv
outdir : core-hello-results
Institutional config options
config_profile_name : Test profile
config_profile_description: Minimal test dataset to check pipeline function
Generic options
trace_report_suffix : 2025-11-21_04-47-18
Core Nextflow options
runName : scruffy_marconi
containerEngine : docker
launchDir : /workspaces/training/hello-nf-core
workDir : /workspaces/training/hello-nf-core/work
projectDir : /workspaces/training/hello-nf-core/core-hello
userName : root
profile : docker,test
configFiles : /workspaces/training/hello-nf-core/core-hello/nextflow.config
!! Only displaying parameters that differ from the pipeline defaults !!
------------------------------------------------------
-[core/hello] Pipeline completed successfully-
Bu, tüm temel bağlantıların yerinde olduğunu gösterir. Peki çıktılar nerede? Var mı?
Aslında, standart yürütme raporlarını içeren core-hello-results adında yeni bir sonuç dizini oluşturuldu:
Dizin içeriği
core-hello-results
└── pipeline_info
├── execution_report_2025-11-21_04-47-18.html
├── execution_timeline_2025-11-21_04-47-18.html
├── execution_trace_2025-11-21_04-47-18.txt
├── hello_software_versions.yml
├── params_2025-11-21_04-47-18.json
└── pipeline_dag_2025-11-21_04-47-18.html
1 directory, 6 files
Ne çalıştırıldığını görmek için raporlara bir göz atabilirsiniz ve cevap şu: hiçbir şey!

Kodda gerçekte ne olduğuna bir göz atalım.
1.3. Yer tutucu workflow'u inceleme¶
main.nf dosyasının içine bakarsanız, workflows/hello içinden HELLO adlı bir workflow import ettiğini göreceksiniz.
Bu, Bölüm 1'de karşılaştığımız workflows/demo.nf workflow'una eşdeğerdir ve bazı nf-core işlevleri zaten yerinde olan ilgilendiğimiz workflow için yer tutucu olarak hizmet eder.
Hello Nextflow'da geliştirilen temel bir Nextflow workflow'una kıyasla, burada yeni olan birkaç şey fark edeceksiniz (yukarıdaki vurgulanan satırlar):
- Workflow bloğunun bir adı var
- Workflow girdileri
take:anahtar kelimesi kullanılarak bildirilir ve kanal oluşturma üst workflow'a taşınır - Workflow içeriği bir
main:bloğunun içine yerleştirilir - Çıktılar
emit:anahtar kelimesi kullanılarak bildirilir
Bunlar, workflow'u birleştirilebilir yapan Nextflow'un isteğe bağlı özellikleridir, yani başka bir workflow içinden çağrılabilir.
Derinlemesine birleştirilebilir workflow'lar
Workflows of Workflows Side Quest, workflow kompozisyonunu çok daha derinlemesine inceliyor, birden fazla workflow'u birlikte nasıl oluşturacağınızı ve aralarındaki karmaşık veri akışlarını nasıl yöneteceğinizi içeriyor. Burada birleştirilebilirliği tanıtıyoruz çünkü bu, pipeline başlatma, ana analiz workflow'u ve tamamlama görevlerini ayrı, yeniden kullanılabilir bileşenlere organize etmek için iç içe workflow'lar kullanan nf-core şablon mimarisinin temel bir gereksinimidir.
İlgilendiğimiz workflow'dan ilgili mantığı bu yapıya eklemek zorunda kalacağız. Bunun için ilk adım orijinal workflow'umuzu birleştirilebilir hale getirmektir.
Çıkarım¶
Artık nf-core araçlarını kullanarak bir pipeline iskeleti oluşturmayı biliyorsunuz.
Sırada ne var?¶
Basit bir workflow'u nf-core uyumlu hale getirmenin bir ön adımı olarak nasıl birleştirilebilir yapacağınızı öğrenin.
2. Orijinal Hello Nextflow workflow'unu birleştirilebilir hale getirme¶
Şimdi workflow'umuzu nf-core iskeletine entegre etmek için çalışma zamanı. Hatırlatma olarak, Hello Nextflow eğitim kursumuzdaki workflow ile çalışıyoruz.
Tip
O pipeline'a aşina değilseniz veya hatırlatmaya ihtiyacınız varsa, The Hello pipeline sayfasına bakın.
Size, tamamlanmış Hello Nextflow workflow'unun temiz, tamamen işlevsel bir kopyasını original-hello dizininde modülleri ve girdi olarak kullanmasını beklediği varsayılan CSV dosyası ile birlikte sağlıyoruz.
Dizin içeriği
Çalıştığından emin olmak için çekinmeden çalıştırın:
Komut çıktısı
Kodu incelemek için hello.nf workflow dosyasını açalım, aşağıda tam olarak gösterilmiştir (modüller içinde olan process'ler sayılmaz):
Gördüğünüz gibi, bu workflow kendi başına çalıştırılabilen basit bir adsız workflow olarak yazılmıştır. Bunu nf-core şablonunun gerektirdiği gibi bir üst workflow içinden çalıştırılabilir hale getirmek için birleştirilebilir yapmamız gerekiyor.
Gerekli değişiklikleri tek tek inceleyelim.
2.1. Workflow'a ad verme¶
İlk olarak, workflow'a bir üst workflow'dan ona başvurabilmek için bir ad verelim.
Workflow adları için modül adlarında olduğu gibi aynı kurallar geçerlidir.
2.2. Kanal oluşturmayı take ile değiştirme¶
Şimdi, kanal oluşturmayı beklenen girdileri bildiren basit bir take ifadesi ile değiştirin.
Bu, girdilerin nasıl sağlandığının ayrıntılarını üst workflow'a bırakır.
Bu arada, params.greeting = 'greetings.csv' satırını da yorum satırı yapabiliriz
Note
Nextflow dil sunucusu uzantısı yüklüyse, sözdizimi denetleyicisi kodunuzu kırmızı dalgalı çizgilerle işaretleyecektir.
Bunun nedeni, bir take: ifadesi koyarsanız, aynı zamanda bir main: de olması gerektiğidir.
Bunu bir sonraki adımda ekleyeceğiz.
2.3. Workflow işlemlerinin önüne main ifadesi ekleme¶
Ardından, workflow gövdesinde çağrılan işlemlerin geri kalanından önce bir main ifadesi ekleyin.
Bu temel olarak 'bu workflow'un yaptığı budur' der.
2.4. emit ifadesi ekleme¶
Son olarak, workflow'un son çıktılarının ne olduğunu bildiren bir emit ifadesi ekleyin.
Bu, orijinal workflow'a kıyasla koda tamamen yeni bir eklentidir.
2.5. Tamamlanan değişikliklerin özeti¶
Tüm değişiklikleri açıklandığı gibi yaptıysanız, workflow'unuz şimdi şöyle görünmelidir:
Bu, Nextflow'un ihtiyaç duyduğu her şeyi açıklar, girdi kanalına ne besleyeceğimiz HARİÇ. Bu, giriş noktası workflow'u olarak da adlandırılan üst workflow'da tanımlanacaktır.
2.6. Kukla bir giriş noktası workflow'u yapma¶
Birleştirilebilir workflow'umuzu karmaşık nf-core iskeletine entegre etmeden önce, doğru çalıştığını doğrulayalım. Birleştirilebilir workflow'u izole bir şekilde test etmek için basit bir kukla giriş noktası workflow'u yapabiliriz.
Aynı original-hello dizininde main.nf adında boş bir dosya oluşturun.
Aşağıdaki kodu main.nf dosyasına kopyalayın.
Burada yapılacak iki önemli gözlem var:
- İçe aktarılan workflow'u çağırma sözdizimi, modülleri çağırma sözdizimi ile esasen aynıdır.
- Girdileri workflow'a çekmeyle ilgili her şey (girdi parametresi ve kanal oluşturma) artık bu üst workflow'da bildirilir.
Note
Giriş noktası workflow dosyasını main.nf olarak adlandırmak bir kural, bir gereklilik değildir.
Bu kurala uyarsanız, nextflow run komutunuzda workflow dosya adını belirtmeyi atlayabilirsiniz.
Nextflow, yürütme dizininde main.nf adlı bir dosyayı otomatik olarak arayacaktır.
Ancak, isterseniz giriş noktası workflow dosyasını başka bir şey olarak adlandırabilirsiniz.
Bu durumda, nextflow run komutunuzda workflow dosya adını belirttiğinizden emin olun.
2.7. Workflow'un çalıştığını test etme¶
Sonunda birleştirilebilir workflow'un çalıştığını doğrulamak için ihtiyacımız olan tüm parçalara sahibiz. Hadi çalıştıralım!
Burada main.nf adlandırma kuralını kullanmanın avantajını görüyorsunuz.
Giriş noktası workflow'unu something_else.nf olarak adlandırsaydık, nextflow run original-hello/something_else.nf yapmak zorunda kalacaktık.
Tüm değişiklikleri doğru yaptıysanız, bu tamamlanana kadar çalışmalıdır.
Komut çıktısı
N E X T F L O W ~ version 25.04.3
Launching `original-hello/main.nf` [friendly_wright] DSL2 - revision: 1ecd2d9c0a
executor > local (8)
[24/c6c0d8] HELLO:sayHello (3) | 3 of 3 ✔
[dc/721042] HELLO:convertToUpper (3) | 3 of 3 ✔
[48/5ab2df] HELLO:collectGreetings | 1 of 1 ✔
[e3/693b7e] HELLO:cowpy | 1 of 1 ✔
Output: /workspaces/training/hello-nf-core/work/e3/693b7e48dc119d0c54543e0634c2e7/cowpy-COLLECTED-test-batch-output.txt
Bu, HELLO workflow'umuzu başarıyla birleştirilebilir hale getirdiğimiz anlamına gelir.
Çıkarım¶
Bir workflow'u adlandırarak ve take, main ve emit ifadeleri ekleyerek nasıl birleştirilebilir yapacağınızı ve bir giriş noktası workflow'undan nasıl çağıracağınızı biliyorsunuz.
Sırada ne var?¶
Temel bir birleştirilebilir workflow'u nf-core iskeletine nasıl aşılayacağınızı öğrenin.
3. Güncellenmiş workflow mantığını yer tutucu workflow'a uydurma¶
Artık birleştirilebilir workflow'umuzun doğru çalıştığını doğruladığımıza göre, bölüm 1'de oluşturduğumuz nf-core pipeline iskeletine geri dönelim. Az önce geliştirdiğimiz birleştirilebilir workflow'u nf-core şablon yapısına entegre etmek istiyoruz, böylece sonuç şuna benzer bir şey olmalıdır.
Peki bunu nasıl gerçekleştiririz? core-hello/workflows/hello.nf içindeki (nf-core iskeleti) HELLO workflow'unun mevcut içeriğine bir göz atalım.
Genel olarak bu kod, workflow'da çalıştırılan herhangi bir yazılım aracının sürümünü yakalamakla ilgisi olan bazı temizlik dışında çok az şey yapar.
Bölüm 2'de geliştirdiğimiz orijinal workflow'un birleştirilebilir versiyonundan ilgili kodu eklememiz gerekiyor.
Bunu şu aşamalarda ele alacağız:
- Modülleri kopyalama ve modül import'larını kurma
takebildirimini olduğu gibi bırakma- Workflow mantığını
mainbloğuna ekleme emitbloğunu güncelleme
Note
Bu ilk geçiş için versiyon yakalamayı görmezden geliyoruz ve bunun nasıl bağlanacağını bu eğitimin daha sonraki bir bölümünde inceleyeceğiz.
3.1. Modülleri kopyalama ve modül import'larını kurma¶
Hello Nextflow workflow'umuzdaki dört process, original-hello/modules/ içinde modül olarak saklanır.
Bu modülleri nf-core proje yapısına (core-hello/modules/local/ altına) kopyalamamız ve nf-core workflow dosyasına import ifadeleri eklememiz gerekiyor.
İlk olarak modül dosyalarını original-hello/'dan core-hello/'ya kopyalayalım:
Şimdi modül dizininin core-hello/ altında listelendiğini görmelisiniz.
Dizin içeriği
Şimdi modül import ifadelerini kuralım.
Bunlar original-hello/hello.nf workflow'undaki import ifadeleriydi:
| original-hello/hello.nf | |
|---|---|
core-hello/workflows/hello.nf dosyasını açın ve bu import ifadelerini aşağıda gösterildiği gibi ona aktarın.
Burada iki ilginç gözlem daha:
- Import ifadelerinin biçimlendirmesini nf-core stil kuralına uyacak şekilde uyarladık.
- Modüllerin göreceli yollarını, artık farklı bir iç içe yerleşme seviyesinde saklandıklarını yansıtacak şekilde güncelledik.
3.2. take bildirimini olduğu gibi bırakma¶
nf-core projesinin, tipik olarak sütunsal veri içeren bir CSV dosyası olan samplesheet kavramı etrafında çok sayıda önceden oluşturulmuş işlevselliği vardır.
greetings.csv dosyamız esasen bu olduğundan, mevcut take bildirimini olduğu gibi tutacağız ve bir sonraki adımda sadece girdi kanalının adını güncelleyeceğiz.
| core-hello/workflows/hello.nf | |
|---|---|
Girdi işleme bu workflow'un yukarısında yapılacaktır (bu kod dosyasında değil).
3.3. Workflow mantığını main bloğuna ekleme¶
Şimdi modüllerimiz workflow'a açık olduğuna göre, workflow mantığını main bloğuna ekleyebiliriz.
Hatırlatma olarak, orijinal workflow'daki ilgili kod şudur, birleştirilebilir yaptığımızda pek değişmedi (sadece main: satırını ekledik):
main:'den sonra gelen kodu workflow'un yeni versiyonuna kopyalamamız gerekiyor.
Orada zaten workflow tarafından çalıştırılan araçların sürümlerini yakalamakla ilgili bazı kodlar var. Şimdilik bunu olduğu gibi bırakacağız (araç versiyonlarıyla daha sonra ilgileneceğiz).
ch_versions = channel.empty() başlatmasını en üstte tutacağız, ardından workflow mantığımızı ekleyeceğiz, versiyon harmanlama kodunu sonda tutacağız.
Bu sıralama mantıklıdır çünkü gerçek bir pipeline'da, process'ler workflow çalışırken ch_versions kanalına eklenecek sürüm bilgisi yayar.
Ayrıca kodu daha okunabilir yapmak için main:'den önce boş bir satır eklediğimizi fark edeceksiniz.
Bu harika görünüyor, ancak sayHello() process'ine ilettiğimiz kanalın adını aşağıda gösterildiği gibi greeting_ch'den ch_samplesheet'e, take: anahtar kelimesi altında yazılanla eşleşecek şekilde güncellememiz gerekiyor.
Şimdi workflow mantığı doğru şekilde bağlandı.
3.4. emit bloğunu güncelleme¶
Son olarak, workflow'un son çıktılarının bildirimini içerecek şekilde emit bloğunu güncellememiz gerekiyor.
Bu, HELLO workflow'unun kendisinde yapmamız gereken değişiklikleri tamamlar. Bu noktada, uygulamaya koymayı amaçladığımız genel kod yapısına ulaştık.
Çıkarım¶
Birleştirilebilir bir workflow'un temel parçalarını bir nf-core yer tutucu workflow'una nasıl yerleştireceğinizi biliyorsunuz.
Sırada ne var?¶
nf-core pipeline iskeletinde girdilerin nasıl işlendiğini nasıl uyarlayacağınızı öğrenin.
4. Girdi işlemeyi uyarlama¶
Artık workflow mantığımızı nf-core iskeletine başarıyla entegre ettiğimize göre, bir kritik parçayı daha ele almamız gerekiyor: girdi verilerimizin doğru şekilde işlendiğinden emin olmak.
nf-core şablonu, karmaşık genomik veri kümeleri için tasarlanmış sofistike girdi işleme ile birlikte gelir, bu yüzden onu daha basit greetings.csv dosyamızla çalışacak şekilde uyarlamamız gerekiyor.
4.1. Girdilerin nerede işlendiğini belirleme¶
İlk adım, girdi işlemenin nerede yapıldığını bulmaktır.
Hello Nextflow workflow'unu birleştirilebilir olacak şekilde yeniden yazdığımızda, girdi parametresi bildirimini bir seviye yukarı, main.nf giriş noktası workflow'una taşıdığımızı hatırlayabilirsiniz.
O halde, pipeline iskeleti kapsamında oluşturulan üst düzey main.nf giriş noktası workflow'una bir göz atalım:
nf-core projesi iç içe subworkflow'ları yoğun bir şekilde kullanır, bu yüzden bu kısım ilk yaklaşımda biraz kafa karıştırıcı olabilir.
Burada önemli olan iki workflow tanımlanmıştır:
CORE_HELLO,core-hello/workflows/hello.nfiçinde az önce uyarlamayı bitirdiğimiz HELLO workflow'unu çalıştırmak için ince bir sarmalayıcıdır.CORE_HELLO'yu ve iki diğer subworkflow'u,PIPELINE_INITIALISATIONvePIPELINE_COMPLETION'ı çağıran adsız bir workflow.
İşte birbirleriyle nasıl ilişkili olduklarının bir diyagramı:
Önemlisi, bu seviyede bir girdi kanalı oluşturan herhangi bir kod bulamıyoruz, yalnızca --input parametresi aracılığıyla sağlanan bir samplesheet'e referanslar.
Biraz araştırma, girdi işlemenin uygun bir şekilde core-hello/subworkflows/local/utils_nfcore_hello_pipeline/main.nf'den import edilen PIPELINE_INITIALISATION subworkflow'u tarafından yapıldığını ortaya çıkarır.
Bu dosyayı açıp aşağı kaydırırsak, bu kod bloğuna geliriz:
Bu, samplesheet'i ayrıştıran ve HELLO workflow'u tarafından tüketilmeye hazır bir biçimde ileten kanal fabrikasıdır.
Note
Yukarıdaki sözdizimi daha önce kullandığımızdan biraz farklı, ancak temelde bu:
şuna eşdeğerdir:
Bu kod, yazım zamanında çok alana özgü olan ve basit pipeline projemiz için uygun olmayan nf-core pipeline şablonuna dahil edilen örnek samplesheet'e oldukça özgü bazı ayrıştırma ve doğrulama adımları içerir.
4.2. Şablonlu girdi kanalı kodunu değiştirme¶
İyi haber, pipeline'ımızın ihtiyaçlarının çok daha basit olması, bu yüzden tüm bunları orijinal Hello Nextflow workflow'unda geliştirdiğimiz kanal oluşturma koduyla değiştirebiliriz.
Hatırlatma olarak, kanal oluşturma şöyle görünüyordu (çözümler dizininde görüldüğü gibi):
| solutions/composable-hello/main.nf | |
|---|---|
Yani sadece bunu küçük değişikliklerle başlatma workflow'una eklememiz gerekiyor: kanal adını greeting_ch'den ch_samplesheet'e ve parametre adını params.greeting'den params.input'a güncelliyoruz (vurgulanan satıra bakın).
| core-hello/subworkflows/local/utils_nfcore_hello_pipeline/main.nf | |
|---|---|
Bu, girdi işlemenin çalışmasını sağlamak için yapmamız gereken değişiklikleri tamamlar.
Mevcut haliyle, bu bizi şema doğrulaması için nf-core'un yerleşik yeteneklerinden yararlanmamıza izin vermez, ancak bunu daha sonra ekleyebiliriz. Şimdilik, test verileri üzerinde başarıyla çalıştırabileceğimiz bir şeye ulaşmak için mümkün olduğunca basit tutmaya odaklanıyoruz.
4.3. Test profilini güncelleme¶
Test verileri ve parametrelerden bahsetmişken, bu pipeline'ın test profilini şablonda sağlanan örnek samplesheet yerine greetings.csv mini-samplesheet'i kullanacak şekilde güncelleyelim.
core-hello/conf altında, küçük bir veri örneğini ve tam boyutlu birini test etmek için tasarlanan iki şablonlu test profili buluyoruz: test.config ve test_full.config.
Pipeline'ımızın amacı göz önüne alındığında, tam boyutlu bir test profili kurmanın gerçekten bir anlamı yok, bu yüzden test_full.config'i görmezden gelmekten veya silmekten çekinmeyin.
Birkaç varsayılan parametreyle greetings.csv dosyamızda çalışacak şekilde test.config'i kurmaya odaklanacağız.
4.3.1. greetings.csv dosyasını kopyalama¶
Öncelikle greetings.csv dosyasını pipeline projemizde uygun bir yere kopyalamamız gerekiyor.
Tipik olarak küçük test dosyaları assets dizininde saklanır, o halde dosyayı çalışma dizinimizden kopyalayalım.
Şimdi greetings.csv dosyası test girdisi olarak kullanılmaya hazır.
4.3.2. test.config dosyasını güncelleme¶
Şimdi test.config dosyasını aşağıdaki gibi güncelleyebiliriz:
| core-hello/conf/test.config | |
|---|---|
Önemli noktalar:
${projectDir}kullanımı: Bu, ana workflow betiğinin bulunduğu dizine (pipeline kökü) işaret eden bir Nextflow örtük değişkenidir. Bunu kullanmak, yolun pipeline'ın nereden çalıştırıldığından bağımsız olarak çalışmasını sağlar.- Mutlak yollar:
${projectDir}kullanarak, küçük test dosyaları için önemli olan mutlak bir yol oluşturuyoruz. - Test verisi konumu: nf-core pipeline'ları tipik olarak küçük test dosyaları için pipeline repository'si içindeki
assets/dizininde test verilerini saklar veya daha büyük dosyalar için harici test veri kümelerine referans verir.
Ve bu arada, bunun çok basit makinelerde (Github Codespaces'teki minimal VM'ler gibi) çalışacağından emin olmak için varsayılan kaynak limitlerini sıkılaştıralım:
Bu, yapmamız gereken kod değişikliklerini tamamlar.
4.4. Pipeline'ı test profiliyle çalıştırma¶
Bu çok şeydi, ancak sonunda pipeline'ı çalıştırmayı deneyebiliriz!
Henüz doğrulamayı kurmadığımız için komut satırına --validate_params false eklememiz gerektiğini unutmayın (bu daha sonra gelecek).
Tüm değişiklikleri doğru yaptıysanız, tamamlanana kadar çalışmalıdır.
Komut çıktısı
```console N E X T F L O W ~ version 25.04.3
Launching core-hello/main.nf [condescending_allen] DSL2 - revision: b9e9b3b8de
Input/output options input : /workspaces/training/hello-nf-core/core-hello/assets/greetings.csv outdir : core-hello-results
Institutional config options config_profile_name : Test profile config_profile_description: Minimal test dataset to check pipeline function
Generic options validate_params : false trace_report_suffix : 2025-11-21_07-29-37
Core Nextflow options runName : condescending_allen containerEngine : docker launchDir : /workspaces/training/hello-nf-core workDir : /workspaces/training/hello-nf-core/work projectDir : /workspaces/training/hello-nf-core/core-hello userName : root profile : test,docker configFiles : /workspaces/training/hello-nf-core/core-hello/nextflow.config
!! Only displaying parameters that differ from the pipeline defaults !!¶
executor > local (1) [ed/727b7e] CORE_HELLO:HELLO:sayHello (3) [100%] 3 of 3 ✔ [45/bb6096] CORE_