Kullanım alanı - Use case

Çok basit durum şemasını kullan bir Wiki sistemi.
Yazılım geliştirme
Çekirdek aktiviteleri
Paradigmalar ve modeller
Metodolojiler ve çerçeveler
Destekleyen disiplinler
Uygulamalar
Araçlar
Standartlar ve Bilgi Yapıları
Sözlükler
Anahatlar

İçinde yazılım ve sistem Mühendisi, bir kullanım durumu tipik olarak bir rol arasındaki etkileşimleri tanımlayan eylemlerin veya olay adımlarının bir listesidir ( Birleştirilmiş Modelleme Dili (UML) bir aktör ) ve bir hedefe ulaşmak için bir sistem. Oyuncu, bir insan veya başka bir dış sistem olabilir. Sistem mühendisliğinde, kullanım durumları içerisinden daha yüksek bir düzeyde kullanılır yazılım Mühendisliği, genellikle görevleri temsil eder veya menfaat sahibi hedefler. Ayrıntılı gereksinimler daha sonra Sistem Modelleme Dili (SysML) veya sözleşme beyanları olarak.

Tarih

1987 yılında Ivar Jacobson kullanım durumlarıyla ilgili ilk makaleyi, OOPSLA 87 konferansı.[1] Bu tekniğin nasıl kullanıldığını anlatıyor Ericson metinsel, yapısal ve yapısal özellikleri kullanarak bir sistemin gereksinimlerini yakalamak ve belirlemek için görsel modelleme nesne yönelimli analiz ve tasarımı yürütme teknikleri.[2] Başlangıçta terimleri kullanmıştı kullanım senaryoları ve kullanım durumu - ikincisi, İsveççe teriminin doğrudan çevirisi Användningsfall - ancak bu terimlerin hiçbirinin İngilizce'de kulağa doğal gelmediğini fark etti ve sonunda kullanım durumu.[3]

1992'de kitabın ortak yazarlığını yapıyor Nesneye Yönelik Yazılım Mühendisliği - Kullanım Durumuna Dayalı Bir Yaklaşım,[4] temelini atan OOSE sistem mühendisliği yöntemi ve yakalama için kullanım durumlarının yaygınlaştırılmasına yardımcı oldu işlevsel gereksinimler özellikle yazılım geliştirme. 1994'te kullanım durumları ve uygulanan nesne yönelimli teknikler hakkında bir kitap yayınladı. iş modelleri ve iş sürecinin yeniden yapılanması.[5]

Aynı zamanda, Grady Booch ve James Rumbaugh birleştirmek için çalışmak nesneye yönelik analiz ve tasarım yöntemler, Booch yöntemi ve Nesne Modelleme Tekniği (OMT) sırasıyla. 1995'te Ivar Jacobson onlara katıldı ve birlikte Birleşik Modelleme Dili (UML), kullanım durumu modellemesini içerir. UML, Nesne Yönetim Grubu (OMG) 1997'de.[6] Jacobson, Booch ve Rumbaugh aynı zamanda İtiraz yazılım geliştirme süreci. Sonuç Birleşik Süreç 1999'da yayınlandı ve kullanım senaryosu odaklı bir yaklaşımı teşvik ediyor.[7]

O zamandan beri, birçok yazar tekniğin gelişmesine katkıda bulundu, özellikle: Larry Constantine bağlamında 1995 yılında gelişir kullanım odaklı tasarım, kullanıcı arayüzünün tasarımını kısıtlayabilecek veya önyargılı hale getirebilecek eylem veya senaryo dizileri yerine kullanıcı amaçlarını tanımlamayı amaçlayan "temel kullanım durumları";[8] Alistair Cockburn 2000 yılında metin anlatımlarına ve tablo şartnamelerine dayalı bir amaca yönelik kullanım örneği uygulaması yayınladı;[9] Kurt Bittner ve Ian Spence, 2002'de kullanım senaryoları ile fonksiyonel gereksinimleri analiz etmek için gelişmiş uygulamalar geliştirdi;[10] Dean Leffingwell ve Don Widrig, yönetim ve paydaş iletişim faaliyetlerini değiştirmek için kullanım senaryoları uygulamayı önermektedir;[11] Gunnar Overgaard, 2004 yılında tasarım modellerinin ilkelerini vakaları kullanacak şekilde genişletmeyi önerdi.[12]

Jacobson 2011'de Ian Spence ve Kurt Bittner ile birlikte e-kitabı yayınladı Kullanım Örneği 2.0 tekniği çevik bir bağlama uyarlamak, artımlı kullanım durumu "dilimleri" ile zenginleştirmek ve tüm geliştirme yaşam döngüsü boyunca kullanımını teşvik etmek[13] yıllık olarak yenilenen yaklaşımı sunduktan sonra IIBA konferans.[14][15]

Genel prensip

Kullanım senaryoları, bir sistemin gereksinimlerini yakalamak, modellemek ve belirlemek için kullanılan bir tekniktir.[10] Kullanım senaryosu, sistemin aktörleriyle etkileşim halinde gerçekleştirebileceği ve hedeflerine katkıda bulunan gözlemlenebilir bir sonuç üreten bir dizi davranışa karşılık gelir. Aktörler, etkileşimde insan kullanıcıların veya diğer sistemlerin sahip olduğu rolü temsil eder.

İçinde İhtiyaç analizi Kullanım durumu, tanımlanmasında, birincil aktörü için temsil ettiği belirli kullanıcı hedefine göre adlandırılır. Durum, metinsel bir açıklama ile veya faaliyetlerin ve olayların genel sırasını ve ayrıca özel koşullar, istisnalar veya hata durumları gibi değişkenleri açıklayan ek grafik modellerle daha ayrıntılı olarak açıklanır.

Göre Yazılım Mühendisliği Bilgi Birimi (SWEBOK),[16] kullanım senaryoları senaryo bazlı gereksinim ortaya çıkarma tekniklerin yanı sıra model tabanlı analiz teknikleri. Ancak kullanım senaryoları aynı zamanda anlatıya dayalı gereksinim toplama, artımlı gereksinim edinme, sistem dokümantasyonu ve kabul testini de destekler.[1]

Varyasyonlar

Teknikte farklı kullanım durumları ve varyasyonları vardır:

  • Sistem kullanım durumları, geliştirilecek bir sistemin gereksinimlerini belirtir.[2] Ayrıntılı açıklamalarında sadece aktörlerle olan etkileşimleri değil, aynı zamanda işlemeye dahil olan varlıkları da tanımlarlar. Daha ileri analiz modelleri ve tasarım faaliyetleri için başlangıç ​​noktasıdırlar.
  • İş kullanım örnekleri, bir yazılım sistemi yerine bir iş organizasyonuna odaklanır. İş süreci yeniden yapılandırma girişimleri bağlamında iş modellerini ve iş süreci gereksinimlerini belirlemek için kullanılırlar.[5]
  • Soyut kullanım örnekleri olarak da adlandırılan temel kullanım senaryoları, herhangi bir sıra tanımlamadan veya bir senaryo tanımlamadan aktörlerin potansiyel amaçlarını ve sistemin bunları nasıl ele aldığını açıklar.[8] Bu uygulama, kullanıcı merkezli tasarımı desteklemek ve sistem özelliklerinin ilk aşamasında kullanıcı arayüzü hakkında önyargı uyandırmaktan kaçınmak amacıyla geliştirilmiştir.[7]
  • Use Case 2.0, tekniği çevik geliştirme yöntemleri bağlamına uyarlar.[1] Bu teknik, kullanıcı öyküsü anlatılarını destekleyerek gereksinim toplama uygulamasını zenginleştirir. Ayrıca, gereksinimlerin aşamalı olarak ortaya çıkarılmasını kolaylaştırmak ve aşamalı uygulamayı mümkün kılmak için kullanım durumu "dilimleri" sağlar.

Dürbün

Kullanım senaryosunun kapsamı konuya ve hedeflere göre tanımlanabilir:

  • Denek, etkileşimleri sağlayacak sistemi, alt sistemi veya bileşeni tanımlar.[17]
  • Hedefler, hedefle ilgilenen organizasyonel seviye (örn. Şirket, departman, kullanıcı) ve kullanıcının hedefinin alt hedeflere ayrıştırılması dikkate alınarak hiyerarşik olarak yapılandırılabilir.[9] Hedefin ayrıştırılması, kullanıcıların bakış açısından ve geleneksel fonksiyonel ayrıştırmadan farklı olan sistemden bağımsız olarak gerçekleştirilir.[10]  

Kullanım

Kullanım durumlarının aşağıdaki bağlamlarda uygulanacağı bilinmektedir:

Şablonlar

Metinde bir kullanım örneği yazmanın birçok yolu vardır. kullanım durumu özeti, gündelik, anahat, için tamamen giyinmiş vb. ve çeşitli şablonlarla. Çeşitli satıcılar veya uzmanlar tarafından tasarlanan şablonlarda kullanım senaryoları yazmak, yüksek kaliteli işlevsel sistem gereksinimleri elde etmek için yaygın bir endüstri uygulamasıdır.

Cockburn tarzı

Tarafından tanımlanan şablon Alistair Cockburn kitabında Etkili Kullanım Örnekleri Yazma kullanım alanlarının en yaygın kullanılan yazı stillerinden biri olmuştur.[kaynak belirtilmeli ]

Tasarım kapsamları

Cockburn, kara kutu (iç ayrıntı gizlidir) veya beyaz kutu (iç ayrıntı gösterilmektedir) olabilen "Tasarım Kapsamını" göstermek için her bir kullanım senaryosuna bir sembolle açıklama eklemeyi önerir. Beş sembol mevcuttur:[20]

DürbünSimge
Organizasyon (kara kutu)Dolu EvScope-icons-filled-house
Organizasyon (beyaz kutu)Doldurulmamış Ev
Scope-icons-unfilled-house
Sistem (kara kutu)Dolu Kutu
Scope-icons-filled-box
Sistem (beyaz kutu)Doldurulmamış Kutu
Scope-icons-unfilled-box
BileşenVida veya Cıvata
Scope-icons-screw-bolt

Diğer yazarlar bazen Kuruluş düzeyinde kullanım örneklerini "İş kullanım örnekleri" olarak adlandırırlar.[21]

Hedef seviyeleri

Hedef seviyeleri hiyerarşisi

Cockburn, "Hedef Seviyesini" göstermek için her bir kullanım örneğini bir sembolle açıklamayı önerir;[22] tercih edilen seviye "Kullanıcı hedefi" dir (veya halk dilinde "deniz seviyesi" dir[23]:101).

Hedef DüzeyiSimgeSembol
Çok Yüksek ÖzetBulut++
Goal-level-icons-cloud.png
ÖzetUçan uçurtma+
Goal-level-icons-flying-kite.png
Kullanıcı HedefiDenizdeki Dalgalar!
Goal-level-icons-waves-at-sea.png
Alt fonksiyonBalık-
Goal-level-icons-fish.png
Çok düşükDeniz dibi istiridye kabuğu--
Goal-level-icons-seabed-clam-shell.png

Bazen metin yazarken, bir kullanım durumu adı ve ardından alternatif bir metin sembolü (!, +, -, vb.) Seviyeleri belirtmenin daha kısa ve kolay bir yoludur, ör. sipariş vermek!, oturum aç-.

Tamamen giyinmiş

Cockburn, bir kullanım senaryosu için daha ayrıntılı bir yapı açıklar, ancak daha az ayrıntı gerektiğinde basitleştirilmesine izin verir. Tam giyimli kullanım örneği şablonu aşağıdaki alanları listeler:[24]

  • Başlık: "birincil oyuncunun amacını belirten etkin fiil hedef cümlesi"[25]
  • Birincil Aktör
  • Bağlamda Hedef
  • Dürbün
  • Seviye
  • Paydaşlar ve İlgi Alanları
  • Ön koşul
  • Minimum Garantiler
  • Başarı Garantileri
  • Tetikleyici
  • Ana Başarı Senaryosu
  • Uzantılar
  • Teknoloji ve Veri Varyasyonları Listesi

Ayrıca Cockburn, her bir kullanım senaryosunun doğasını belirtmek için iki cihaz kullanılmasını önerir: tasarım kapsamı ve hedef seviyesi için simgeler.

Cockburn'ün yaklaşımı diğer yazarları etkiledi; örneğin, Alexander ve Beus-Dukic, Cockburn'ün "Tam giyimli kullanım senaryosu" şablonunu yazılımdan her türden sisteme doğru genelleştirir ve aşağıdaki alanlar Cockburn'den farklıdır:[26]

  • Varyasyon senaryoları "(belki ana senaryodan ayrılıyor ve belki ana senaryoya dönüyor)"
  • İstisnalar "yani istisna olayları ve istisna işleme senaryoları"

Gündelik

Cockburn, projelerin her zaman ayrıntılı "tam giyimli" kullanım durumlarına ihtiyaç duymayabileceğinin farkındadır. Alanlarla bir Günlük kullanım durumunu açıklıyor:[24]

  • Başlık (hedef)
  • Birincil Aktör
  • Dürbün
  • Seviye
  • (Öykü): Kullanım senaryosunun ana hatları, ne olduğunu gayri resmi olarak açıklayan basitçe bir veya iki paragraftır.

Fowler tarzı

Martin Fowler "Bir kullanım senaryosunun içeriğini yazmanın standart bir yolu yoktur ve farklı formatlar farklı durumlarda iyi çalışır" diyor.[23]:100 "Kullanılacak ortak bir stili" şu şekilde tanımlıyor:[23]:101

  • Başlık: "kullanım senaryosunun tatmin etmeye çalıştığı hedef"[23]:101
  • Ana Başarı Senaryosu: adımların numaralı listesi[23]:101
    • Adım: "Oyuncu ve sistem arasındaki etkileşimin basit bir ifadesi"[23]:101
  • Uzantılar: ayrı numaralandırılmış listeler, her Uzantı için bir tane[23]:101
    • Uzantı: "ana başarı senaryosundan farklı etkileşimlerle sonuçlanan bir koşul". Ana adım 3'teki bir uzantı 3a, vb. Olarak numaralandırılmıştır.[23]:101

Fowler stili, Cockburn şablonunun basitleştirilmiş bir çeşidi olarak da görülebilir.

Aktörler

Kullanım senaryosu, bir hedefe ulaşmak için dış aktörler ve söz konusu sistem arasındaki etkileşimleri tanımlar. Aktörlerin karar verebilmesi gerekir, ancak insan olmaları gerekmez: "Bir aktör bir kişi, bir şirket veya kuruluş, bir bilgisayar programı veya bir bilgisayar sistemi - donanım, yazılım veya her ikisi olabilir."[27] Aktörler her zaman paydaşlar ancak tüm paydaşlar aktör değildir çünkü "sistemin nasıl davrandığını önemseme hakkına sahip olsalar bile sistemle hiçbir zaman doğrudan etkileşime girmezler."[27] Örneğin, "sistemin sahipleri, şirketin yönetim kurulu ve İç Gelir İdaresi ve Sigorta Dairesi gibi düzenleyici kurumlar" paydaş olabilir, ancak aktör olma ihtimali düşüktür.[27]

Benzer şekilde, bir sistemi kullanan bir kişi, farklı roller oynadığı için farklı aktörler olarak temsil edilebilir. Örneğin, "Joe" kullanıcısı, kendi hesabından nakit çekmek için Otomatik Para Çekme Makinesi kullanırken bir Müşteri rolünü oynuyor olabilir veya nakit çekmecesini yeniden stoklamak için sistemi kullanırken Banka Veznesi rolünü oynuyor olabilir. banka.

Oyuncular genellikle bir başkası adına çalışır. Cockburn, "Bu günlerde, sistem kullanıcısının başka biri adına hareket ettiğini yakalamak için 'müşteri için satış temsilcisi' veya 'pazarlama departmanı katibi' yazıyorum." Bu, projeye "kullanıcı arayüzü ve güvenlik izinlerinin" satış temsilcisi ve katip için tasarlanması gerektiğini, ancak müşteri ve pazarlama departmanının sonuçlarla ilgilenen roller olduğunu söyler.[28]

Bir paydaş hem aktif hem de pasif bir rol oynayabilir: örneğin, bir Tüketici hem bir "kitlesel pazar satın alıcısı" (sistemle etkileşime girmeyen) ve bir Kullanıcıdır (satın alınan ürünle aktif olarak etkileşime giren bir aktör).[29] Buna karşılık, bir Kullanıcı hem "normal bir operatör" (sistemi amaçlanan amacı için kullanan bir aktör) hem de "işlevsel yararlanıcı" (sistemin kullanımından yararlanan bir paydaş).[29] Örneğin, "Joe" kullanıcısı hesabından nakit çektiğinde, Otomatik Para Çekme Makinesi'ni çalıştırıyor ve kendi adına bir sonuç alıyor.

Cockburn, bir sistemin paydaşları, bir kullanım senaryosunun birincil ve destekleyici (ikincil) aktörleri, tasarım aşamasındaki sistemin (SuD) kendisi ve son olarak "iç aktörler" arasında, yani sistemin bileşenleri arasından aktörler aramayı tavsiye eder. tasarım altında.[27]

İş kullanım örneği

Bir kullanım senaryosunun bir kullanıcı (veya başka bir Aktör türü) ile bir sistem arasındaki bir dizi olayı ve etkileşimi tanımlaması gibi, bir değer sonucu (hedef) üretmek için, bir iş kullanım örneği daha genel etkileşimi tanımlar bir iş sistemi ile bu sistemin kullanıcıları / aktörleri arasında değer taşıyan iş sonuçları üretmek için. Birincil fark, bir iş kullanım senaryosu modelinde ele alınan sistemin, teknolojik sistemlere ek olarak insanları da içerebilmesidir. Bu "sistemdeki insanlara" iş işçileri denir. Bir restoran örneğinde, her kişiye bir aktör (dolayısıyla sistemin dışında) veya bir iş çalışanı (sistemin içinde) muamelesi yapılıp yapılmayacağına karar verilmelidir. Aşağıdaki örnekte gösterildiği gibi bir garson oyuncu olarak kabul edilirse, restoran sistemi garsonu içermez ve model garson ile restoran arasındaki etkileşimi ortaya çıkarır. Bir alternatif, müşterinin sistemin dışında (bir aktör) olduğunu düşünürken garsonu restoran sisteminin bir parçası (bir iş çalışanı) olarak görmek olabilir.[30]

Bir iş Durum şemasını kullan birkaç modelini gösteriyor iş kullanım durumları Bir restoran (iş sistemi) ve birincil paydaşları (iş aktörleri ve iş çalışanları).

Görsel modelleme

Kullanım örnekleri yalnızca metinler değil, aynı zamanda gerekirse diyagramlardır. İçinde Birleştirilmiş Modelleme Dili kullanım durumları ve aktörler arasındaki ilişkiler, vaka diyagramlarını kullan başlangıçta dayalı Ivar Jacobson 's İtiraz gösterim. SysML bir sistem bloğu düzeyinde aynı gösterimi kullanır.

Ek olarak, diğer davranışsal UML diyagramları aktivite diyagramları, dizi diyagramları, iletişim diyagramları ve durum makinesi diyagramları buna göre kullanım durumlarını görselleştirmek için de kullanılabilir. Özellikle, bir Sistem Sırası Şeması (SSD), genellikle bir kullanım senaryosunun belirli bir senaryosunu görselleştirmek için harici aktörler ile tasarım altındaki sistem (SuD) arasındaki etkileşimleri göstermek için kullanılan bir dizi diyagramıdır.

Kullanım durumu analizi genellikle kullanım durumu diyagramları çizerek başlar. Çevik geliştirme için, kullanım durumlarını ve bazı metinsel açıklamaları, notları veya notları gösteren birçok UML diyagramının bir gereksinim modeli vaka özetleri kullan çok hafif ve küçük veya kolay proje kullanımı için yeterli olacaktır. Vaka metinlerini kullanmak için iyi bir tamamlayıcı olarak, kullanım senaryolarının görsel diyagram gösterimleri de karmaşık sistem davranış gereksinimlerinin daha iyi anlaşılması, iletişimi ve tasarımı için etkili kolaylaştırıcı araçlardır.

Örnekler

Aşağıda, Cockburn tarzı şablonun biraz değiştirilmiş bir sürümüyle yazılmış örnek bir kullanım örneği verilmiştir. Temel akışın veya uzantıların her adımında yalnızca kullanıcı hedeflerinin, alt hedeflerinin veya niyetlerinin ifade edildiği temel kullanım senaryosu açıklamasında düğme, kontrol, form veya diğer UI öğeleri ve işlemleri bulunmadığını unutmayın. Bu uygulama, gereksinim özelliklerini daha net hale getirir ve tasarım ve uygulamaların esnekliğini en üst düzeye çıkarır.

Edit an article.svg

Kullanım Örneği: Bir makaleyi düzenleyin

Birincil Aktör: Üye (Kayıtlı kullanıcı)

Dürbün: a Wiki sistemi

Seviye: ! (Kullanıcı hedefi veya deniz seviyesi)

Kısa: (bir Kullanıcı hikayesi veya bir destan)

Üye, okuduğu bir makalenin herhangi bir bölümünü (makalenin tamamını veya yalnızca bir bölümünü) düzenler. Düzenleme sırasında önizleme ve değişiklik karşılaştırmasına izin verilir.

Paydaşlar

...

Son koşullar

Minimum Garantiler:
Başarı Garantileri:
  • Makale kaydedilir ve güncellenmiş bir görünüm gösterilir.
  • Makale için bir düzenleme kaydı sistem tarafından oluşturulur, böylece makalenin izleyicileri daha sonra güncellemeden haberdar edilebilir.

Ön koşullar:

Düzenleme özelliği etkin olan makale üyeye sunulur.

Tetikleyiciler:

Üye, makale üzerinde bir düzenleme isteği (makalenin tamamı veya yalnızca bir bölüm için) talep eder.

Temel akış:

  1. Sistem, makalenin tüm ilgili içeriği ile doldurulmuş yeni bir editör alanı / kutusu ve üyenin düzenlemesi için bilgilendirici bir düzenleme özeti sunar. Üye sadece makalenin bir bölümünü düzenlemek isterse, bölüm başlığı düzenleme özetinde otomatik olarak doldurulmuş olarak yalnızca bölümün orijinal içeriği gösterilir.
  2. Üye, tatmin olana kadar makalenin içeriğini değiştirir.
  3. Üye düzenleme özetini doldurur, sisteme bu makaleyi izlemek isteyip istemediğini söyler ve düzenlemeyi gönderir.
  4. Sistem makaleyi kaydeder, düzenleme olayını günlüğe kaydeder ve gerekli tüm son işlemleri tamamlar.
  5. Sistem makalenin güncellenmiş görünümünü üyeye sunar.

Uzantılar:

2–3.

a. Önizlemeyi Göster:
  1. Üye seçer Önizlemeyi Göster değiştirilen içeriği gönderir.
  2. Sistem, önizleme için işlenen güncellenmiş içeriğin eklenmesiyle 1. adımı yeniden çalıştırır ve üyeye düzenlemelerinin henüz kaydedilmediğini bildirir ve ardından devam eder.
b. Değişiklikleri göster:
  1. Üye seçer Değişiklikleri göster değiştirilen içeriği gönderir.
  2. Sistem, üye tarafından yapılan güncel düzenlemeler ile makalenin en son kaydedilen sürümü arasındaki farkları karşılaştırmanın sonuçlarını göstermenin yanı sıra 1. adımı yeniden çalıştırır ve ardından devam eder.
c. Düzenlemeyi iptal edin:
  1. Üye seçer İptal etmek.
  2. Sistem, üyenin yaptığı herhangi bir değişikliği atar ve ardından 5. adıma geçer.

4a. Zaman aşımı:

...

Avantajları

Çevik hareketin başlangıcından bu yana, Kullanıcı hikayesi teknik Aşırı Programlama o kadar popüler olmuştur ki, çoğu, tüm projelerin çevik gereksinimleri için tek ve en iyi çözüm olduğunu düşünmektedir. Alistair Cockburn hala kullanım durumları yazmasının beş nedenini listeler çevik geliştirme.[31]

  1. Hedef adlarının listesi, en kısa sistemin neler sunacağının özeti (hatta Kullanıcı hikayeleri ). Aynı zamanda ilk öncelikleri, tahminleri, ekip tahsisini ve zamanlamayı oluşturmak için kullanılacak bir proje planlama iskeleti sağlar.
  2. Her bir kullanım senaryosunun ana başarı senaryosu, dahil olan herkese sistemin temelde ne yapacağı ve ne yapmayacağı konusunda bir anlaşma sağlar. Her bir özel satır öğesi gereksinimi için bağlam sağlar (ör. Ayrıntılı kullanıcı hikayeleri), başka bir yere ulaşması çok zor olan bir bağlam.
  3. Her bir kullanım senaryosunun uzatma koşulları, bir şekilde geliştirme süresinin ve bütçesinin% 80'ini kaplayan tüm küçük, rahatsız edici şeyleri araştırmak için bir çerçeve sağlar. Bir ileriye bakma mekanizması sağlar, böylece paydaşlar yanıt alması uzun zaman alabilecek sorunları tespit edebilir. Bu sorunlar daha sonra programın önüne konabilir ve konulmalıdır, böylece geliştirme ekibi üzerinde çalışmaya başladığında cevaplar hazır olabilir.
  4. Kullanım senaryosu genişletme senaryosu parçaları, birçok ayrıntılı, genellikle aldatıcı ve göz ardı edilen iş sorusuna yanıtlar sağlar: "Bu durumda ne yapmamız gerekiyor?" Programcıların sorunlar üzerinde düşünmelerine yardımcı olan if ... then ... else ifadesiyle eşleşen bir düşünme / dokümantasyon çerçevesidir. Programlama zamanında değil, araştırma zamanında yapılması dışında.
  5. Tam kullanım senaryosu seti, araştırmacıların her kullanıcının ihtiyaçlarını, sistemle ilgili sahip oldukları her hedefi ve dahil olan her iş varyantını düşündüklerini göstermektedir.

Özetle, kullanım senaryolarında sistem gereksinimlerinin belirtilmesi, geleneksel veya diğer yaklaşımlarla karşılaştırıldığında şu görünür faydalara sahiptir:

Kullanıcı odaklı

Kullanım senaryoları, yazılım gereksinimleri belirtme süreci için güçlü, kullanıcı merkezli bir araçtır.[32] Kullanım senaryosu modellemesi tipik olarak temel paydaş rollerinin (aktörler) sistemle ve sistemin yerine getirmesi gereken amaç veya hedefleriyle etkileşim (dış perspektif). Bu kullanıcı hedefleri daha sonra, sistem tarafından sağlanan istenen işlevsel özellikleri veya hizmetleri temsil eden kullanım senaryolarının adları veya başlıkları için ideal adaylar haline gelir. Bu kullanıcı merkezli yaklaşım, bir geliştirici veya sistem (içeriden) perspektifinden speküle edilen önemsiz işlevlerin değil, gerçek iş değerine sahip olan ve kullanıcının gerçekten istediği şeyin geliştirilmesini sağlar.

Kullanım senaryosu yazımı, etki alanında önemli ve değerli bir analiz aracı olmuştur. Kullanıcı Odaklı Tasarım (UCD) yıllarca.

Daha iyi iletişim

Kullanım senaryoları genellikle yapılandırılmış şablonlarla doğal dillerde yazılır. Görsel UML diyagramlarıyla tamamlanan, hemen hemen herkes tarafından anlaşılabilen bu anlatısal metin biçimi (okunaklı gereksinim hikayeleri), müşteriler, son kullanıcılar, geliştiriciler, test uzmanları ve yöneticiler dahil olmak üzere tüm paydaşlar arasında daha iyi ve daha derin iletişim sağlar. Daha iyi iletişim, kalite gereksinimlerine ve dolayısıyla kalite sistemlerinin sağlanmasına neden olur.

Yapılandırılmış keşifle kalite gereksinimleri

Kullanım senaryolarıyla ilgili en güçlü şeylerden biri, kullanım senaryosunun formatlarında bulunur şablonlar, özellikle ana başarı senaryosu (temel akış) ve uzantı senaryosu parçaları (uzantılar, istisnai ve / veya alternatif akışlar). Ön koşullardan son koşullara kadar bir kullanım senaryosunu adım adım analiz etmek, karmaşık, normalde gizlenen ve göz ardı edilen, görünüşte önemsiz ama gerçekçi olarak çoğu zaman maliyetli gereksinimleri belirlemek için kullanım senaryosu akışının temelden uzantılara kadar her eylem adımını araştırmak ve araştırmak (Cockburn'ün bahsettiği gibi) yukarıda), sistematik olarak net, istikrarlı ve kalite gereksinimleri elde etmenin yapılandırılmış ve faydalı bir yoludur.

Kullanıcı hedefine ulaşmak için bir kullanım senaryosunun eylem adımlarını en aza indirmek ve optimize etmek de daha iyi bir etkileşim dizaynı ve kullanıcı deneyimi sistemin.

Test ve kullanıcı belgelerini kolaylaştırın

Bir eylem veya olay akışı yapısına dayalı içerikle, iyi yazılmış kullanım senaryoları modeli, zahmetli bir yatırım olan sistem veya ürünün test senaryolarının ve kullanım kılavuzlarının tasarımı için mükemmel bir temel ve değerli yönergeler olarak hizmet eder ön ödeme. Bir kullanım senaryosunun akış yolları ile test senaryoları arasında bariz bağlantılar vardır. Bir kullanım senaryosundan senaryoları aracılığıyla işlevsel test senaryoları türetmek (bir kullanım senaryosunun örneklerini çalıştırmak) basittir.[33]

Sınırlamalar

Kullanım durumlarının sınırlamaları şunları içerir:

  • Kullanım senaryoları, bir sistemin etkileşime dayalı olmayan gereksinimlerini (algoritma veya matematiksel gereksinimler gibi) yakalamak için pek uygun değildir veya işlevsel olmayan gereksinimler (platform, performans, zamanlama veya güvenlik açısından kritik hususlar gibi). Bunlar, başka bir yerde açıklayıcı olarak daha iyi belirtilir.
  • Kullanım durumlarının tam olarak standart tanımları olmadığından, her proje kendi yorumunu oluşturmalıdır.
  • Bazıları vaka ilişkilerini kullanır, örneğin genişler, yorumlama açısından belirsizdir ve Cockburn tarafından belirtildiği gibi paydaşların anlaması zor olabilir (Problem # 6)[34][kaynak belirtilmeli ]
  • Kullanım senaryosu geliştiricileri, genellikle düzeyini belirlemekte zorlanır. Kullanıcı arayüzü Bir kullanım senaryosuna dahil edilecek (UI) bağımlılığı. Kullanım durumu teorisi, kullanıcı arayüzünün kullanım senaryolarına yansıtılmayacağını öne sürse de, kullanım durumlarının görselleştirilmesini zorlaştırdığı için tasarımın bu yönünü soyutlamak garip olabilir. Yazılım mühendisliğinde bu zorluk uygulama ile çözülür. ihtiyaç izlenebilirliği örneğin bir izlenebilirlik matrisi. UI öğelerini kullanım durumlarıyla ilişkilendirmeye yönelik bir başka yaklaşım, kullanım durumundaki her adıma bir UI tasarımı eklemektir. Buna kullanım senaryosu film şeridi denir.
  • Kullanım senaryoları fazla vurgulanabilir. Bertrand Meyer Sistem tasarımını gerçek anlamda kullanım durumlarından çıkarmak ve diğer potansiyel olarak değerli gereksinim analizi tekniklerini hariç tutarak kullanım senaryolarını kullanmak gibi konuları tartışır.[35]
  • Kullanım senaryoları, test tasarımı için bir başlangıç ​​noktasıdır,[36] ancak her testin kendi başarı kriterleri olması gerektiğinden, kullanım senaryolarının her yol için ayrı son koşullar sağlamak üzere değiştirilmesi gerekebilir.[37]
  • Kullanım durumları, hedefleri ve bağlamları içermesine rağmen, hedeflerin arkasındaki bu hedefler ve motivasyonlar (paydaşların endişeleri ve bunların etkileşimsizliği dahil değerlendirmeleri) çatışması veya diğer sistem hedeflerini olumsuz / olumlu yönde etkilemesi, hedef odaklı gereksinim modelleme tekniklerinin konusudur (örneğin BMM, BEN*, KAOS ve ArchiMate ZIRH).

Yanılgılar

Kullanım örnekleriyle ilgili yaygın yanlış anlamalar şunlardır:

Kullanıcı hikayeleri çevik; kullanım durumları değildir.

Çevik ve Scrum ihtiyaç teknikleri konusunda tarafsızdır. Scrum Primer olarak[38] devletler

Ürün İş Listesi kalemleri herhangi bir şekilde açık ve sürdürülebilir şekilde ifade edilir. Yaygın yanlış anlamanın aksine, Ürün İş Listesi "kullanıcı hikayeleri" içermez; sadece öğeleri içerir. Bu öğeler, kullanıcı hikayeleri, kullanım senaryoları veya grubun yararlı bulduğu diğer gereksinimler yaklaşımı olarak ifade edilebilir. Ancak yaklaşım ne olursa olsun, çoğu öğe müşterilere değer sunmaya odaklanmalıdır.

Kullanım senaryosu teknikleri, bir kullanım senaryosunu aşamalı olarak zenginleştirmek için kullanım senaryosu dilimlerini kullanarak Çevik yaklaşımları hesaba katacak şekilde gelişmiştir.[13]

Kullanım durumları çoğunlukla diyagramlardır.

Craig Larman "kullanım durumları diyagram değil metindir" şeklindeki vurgular.[39]

Kullanım senaryolarında çok fazla kullanıcı arayüzü ile ilgili içerik var.

Bazılarının dediği gibi,

Kullanım senaryoları genellikle, yeni bir sistemin gereksinimlerini sıfırdan yakalamak için uygun olmayan bir ayrıntı düzeyi (yani etiketlerin ve düğmelerin adlandırılması) içerecektir.

Acemi yanlış anlamalar. İyi yazılmış bir kullanım senaryosunun her adımı, aktör amaçlar veya niyetler (işlevsel gereksinimlerin özü) ve normalde herhangi bir kullanıcı arabirimi ayrıntısı içermemelidir, ör. etiketlerin ve düğmelerin adlandırılması, UI işlemleri vb. kötü pratik yapar ve kullanım senaryosu yazımını gereksiz yere karmaşıklaştırır ve uygulamasını sınırlar.

Yeni bir sistem için gereksinimleri sıfırdan yakalamaya gelince, vaka diyagramlarını kullan artı vaka özetleri kullan genellikle kullanışlı ve değerli araçlar olarak kullanılır, en az Kullanıcı hikayeleri.

Büyük sistemler için kullanım senaryoları yazmak sıkıcı ve zaman kaybıdır.

Bazılarının dediği gibi,

Kullanım senaryosunun formatı, büyük bir sistemi (örneğin, CRM sistemi) birkaç yüz sayfadan daha az bir şekilde tanımlamayı zorlaştırır. Bu zaman alıcıdır ve kendinizi gereksiz miktarda yeniden çalışma yaparak zaman geçirirken bulacaksınız.

Hiç veya çok az değer katan ve çok fazla yeniden çalışma ile sonuçlanan sıkıcı kullanım senaryoları yazmak için çok zaman harcamak, kötü koku yazarların çok yetenekli olmadıklarını ve kaliteli kullanım senaryolarının hem verimli hem de etkili bir şekilde nasıl yazılacağı konusunda çok az bilgiye sahip olduklarını gösterir. Kullanım senaryoları yinelemeli, artımlı ve evrimsel olarak yazılmalıdır (çevik) yolu. Kullanım senaryosu şablonlarının uygulanması, bir kullanım senaryosu şablonunun tüm alanlarının önceden veya özel olarak ayrılmış bir aşamada, yani geleneksel uygulamadaki gereksinim aşamasında kapsamlı bir şekilde kullanılması ve doldurulması gerektiği anlamına gelmez. şelale geliştirme modeli.

Aslında, formüle edilmiş kullanım durumu formatları bu popüler şablon stilleri, Örneğin. RUP'lar ve Cockburn'ler (ayrıca OUM yöntemi ) vb., büyük sistemlerin karmaşık gereksinimlerini yakalamak, analiz etmek ve belgelemek için değerli ve yardımcı araçlar olarak pratikte kanıtlanmıştır. İyi bir kullanım durumu belgesinin kalitesi (model) büyük ölçüde veya yalnızca boyutuna göre değerlendirilmemelidir. Büyük bir sistemin kaliteli ve kapsamlı bir kullanım senaryosu modelinin, esas olarak sistemin doğasında olan karmaşıklığı nedeniyle nihayet yüzlerce sayfaya dönüşmesi de mümkündür. sorun yazarlarının zayıf yazma becerileri yüzünden değil.

Araçlar

Metin düzenleyiciler ve / veya kelime işlemcileri şablon desteği ile genellikle kullanım durumları yazmak için kullanılır. Büyük ve karmaşık sistem gereksinimleri için, özel kullanım durumu araçları yararlıdır.

İyi bilinen kullanım senaryosu araçlarından bazıları şunları içerir:

Çoğu UML araçları hem metin yazmayı hem de kullanım durumlarının görsel modellemesini destekler.

Ayrıca bakınız

Referanslar

  1. ^ a b c d Dr. Ivar Jacobson; Ian Spence; Kurt Bittner (Aralık 2011). "Use-Case 2.0 e-kitap". Ivar Jacobson Uluslararası. s. 4. Alındı 9 Ağustos 2020.
  2. ^ a b Jacobson, Ivar (1 Aralık 1987). "Endüstriyel bir ortamda nesneye yönelik geliştirme". ACM SIGPLAN Bildirimleri. 22 (12): 183–191. doi:10.1145/38807.38824.
  3. ^ Cockburn, Alistair (Mart 2002). "Kullanım durumları, on yıl sonra". Alistair.cockburn.us. Alistair Cockburn. Arşivlenen orijinal 15 Eylül 2008'de. Alındı 17 Nisan 2013.
  4. ^ a b Jacobson Ivar; Christerson Magnus; Jonsson Patrik; Övergaard Gunnar (1992). Nesneye yönelik yazılım mühendisliği: kullanım senaryosu odaklı bir yaklaşım. ACM Basın. ISBN  0-201-54435-0. OCLC  26132801.
  5. ^ a b Jacobson, Ivar .; Ericsson, Maria; Jacobson, Agneta (1995). Nesne avantajı: Nesne teknolojisi ile iş süreci yeniden yapılandırması. Addison-Wesley. ISBN  0-201-42289-1. OCLC  32276135.
  6. ^ "Birleşik Modelleme Dili Belirtimi Sürümü 2.5.1 Hakkında". www.omg.org. Alındı 9 Ağustos 2020.
  7. ^ a b c d Birleşik yazılım geliştirme süreci. Jacobson, Ivar., Booch, Grady., Rumbaugh, Jim. Okuma, Massachusetts: Addison-Wesley. 1999. ISBN  0-201-57169-2. OCLC  636807532.CS1 Maint: diğerleri (bağlantı)
  8. ^ a b Constantine, Larry L. (1 Nisan 1995). "Temel modelleme: kullanıcı arayüzleri için kullanım örnekleri". Etkileşimler. 2 (2): 34–46. doi:10.1145/205350.205356. S2CID  17209049.
  9. ^ a b Cockburn, Alistair. (2001). Etkili kullanım senaryoları yazmak. Addison-Wesley. ISBN  0-201-70225-8. OCLC  44046973.
  10. ^ a b c Bittner, Kurt (2003). Durum modelleme kullanın. Spence, Ian. Addison Wesley. ISBN  0-201-70913-9. OCLC  50041546.
  11. ^ Leffingwell, Dean. (2003). Yazılım gereksinimlerini yönetme: bir kullanım örneği yaklaşımı. Widrig, Don. (2. baskı). Addison-Wesley. ISBN  0-321-12247-X. OCLC  51653240.
  12. ^ Övergaard, Gunnar. (2005). Kullanım senaryoları: desenler ve planlar. Palmkvist, Karin. Indianapolis, Ind .: Addison-Wesley. ISBN  0-13-145134-0. OCLC  59554401.
  13. ^ a b Jacobson, Ivar; Spence, Ian; Bittner, Kurt (Aralık 2011). "Kullanım Örneği 2.0: Kullanım Durumlarında Başarılı Olma Rehberi". Ivar Jacobson Uluslararası. Alındı 5 Mayıs 2014.
  14. ^ "Business Analysis Conference Europe 2011 - 26-28 Eylül 2011, Londra, İngiltere". Irmuk.co.uk. Arşivlenen orijinal 17 Haziran 2013 tarihinde. Alındı 17 Nisan 2013.
  15. ^ "Use-Case 2.0 Sunumu". Ivar Jacobson Uluslararası. 27 Eylül 2011. Alındı 9 Ağustos 2020.
  16. ^ IEEE Bilgisayar Topluluğu (2014). SWEBOK: Yazılım mühendisliği bilgi birikimi kılavuzu. Bourque, Pierre, Fairley, R. E. (Richard E.) (Sürüm 3.0 ed.). IEEE Bilgisayar Topluluğu. sayfa 1-6 ila 1-8. ISBN  978-0-7695-5166-1. OCLC  880350861.
  17. ^ a b Nesne Yönetim Grubu (2017). "Birleşik Modelleme Dili Spesifikasyonu Sürümü 2.5.1". www.omg.org. Alındı 16 Ağustos 2020.
  18. ^ Wiegers, Karl Eugene (2010). Yazılım gereksinimleri hakkında daha fazla bilgi: çetrefilli sorunlar ve pratik tavsiyeler. Microsoft Press. s. Bölüm 11. ISBN  978-0-7356-2267-8. OCLC  73814167.
  19. ^ Ambler, Scott (2004). "Sistem Kullanım Durumları: Çevik Bir Giriş". agilemodeling.com. Alındı 16 Ağustos 2020.
  20. ^ Cockburn, 2001. Ön kapağın içi. Simgeler "Tasarım Kapsamı".
  21. ^ Suzanne Robertson. Gereksinim Bulma Senaryoları. Bölüm 3, Alexander ve Maiden, 2004. Sayfa 39-59.
  22. ^ Cockburn, 2001. Ön kapağın içi. Simgeler "Hedef Seviyesi".
  23. ^ a b c d e f g h Fowler, 2004.
  24. ^ a b Cockburn, 2001. Sayfa 120.
  25. ^ Cockburn, 2001. Arka kapağın içi. Alan "Kullanım Örneği Başlığı".
  26. ^ Alexander ve Beus-Dukic, 2009. Sayfa 121
  27. ^ a b c d Cockburn, 2001. Sayfa 53.
  28. ^ Cockburn, 2001. Sayfa 55.
  29. ^ a b Alexander ve Beus-Dukic, 2009. Sayfa 39.
  30. ^ Eriksson, Hans-Erik (2000). UML ile İş Modellemesi. New York: Wiley Bilgisayar Yayınları. pp.52. ISBN  0-471-29551-5.
  31. ^ Cockburn, Alistair (9 Ocak 2008). "Neden hala kullanım alanlarını kullanıyorum?". alistair.cockburn.us.
  32. ^ Karl Wiegers (Mart 1997). "Müşterinin Sesini Dinlemek". Süreç Etkisi. Yazılım geliştirme.
  33. ^ Peter Zielczynski (Mayıs 2006). "Kullanım Durumlarından Test Durumlarına İzlenebilirlik". IBM developerWorks.
  34. ^ "Alistair.Cockburn.us - Amaçlarla kullanım örneklerini yapılandırma". alistair.cockburn.us. Alındı 16 Mart 2018.
  35. ^ Meyer, 2000. (sayfa gerekli)
  36. ^ Armor and Miller, 2000. (sayfa gerekli)
  37. ^ Denney, 2005. (sayfa gerekli)
  38. ^ Pete Deemer; Gabrielle Benefield; Craig Larman; Bas Vodde (17 Aralık 2012). "Scrum Primer: Scrum Teorisi ve Pratiğine Yönelik Hafif Bir Kılavuz (Sürüm 2.0)". InfoQ.
  39. ^ Larman Craig (2005). UML ve kalıpları uygulama. Prentice Hall. s. 63–64. ISBN  0-13-148906-2.

daha fazla okuma

  • Alexander, Ian ve Beus-Dukic, Ljerka. Gereksinimleri Keşfetme: Ürün ve Hizmetler Nasıl Belirlenir. Wiley, 2009.
  • Alexander, Ian ve Maiden, Neil. Senaryolar, Hikayeler, Kullanım Örnekleri. Wiley 2004.
  • Armor, Frank ve Granville Miller. Gelişmiş Kullanım Durumu Modellemesi: Yazılım Sistemleri. Addison-Wesley, 2000.
  • Kurt Bittner, Ian Spence, Kullanım Durumu Modellemesi, Addison-Wesley Professional, 20 Ağustos 2002.
  • Cockburn, Alistair. Etkili Kullanım Durumlarının Yazılması. Addison-Wesley, 2001.
  • Larry Constantine, Lucy Lockwood, Kullanım için Yazılım: Temel Modeller ve Kullanım Odaklı Tasarım Yöntemleri için Pratik Bir Kılavuz, Addison-Wesley, 1999.
  • Denney, Richard. Kullanım Durumlarında Başarılı Olmak: Kalite Sağlamak için Akıllıca Çalışmak. Addison-Wesley, 2005.
  • Fowler, Martin. UML Distile (Üçüncü Baskı). Addison-Wesley, 2004.
  • Jacobson Ivar, Christerson M., Jonsson P., Övergaard G., Nesneye Yönelik Yazılım Mühendisliği - Kullanım Durumuna Dayalı Bir Yaklaşım, Addison-Wesley, 1992.
  • Jacobson Ivar, Spence I., Bittner K. Use Case 2.0: Kullanım Durumlarında Başarılı Olma Rehberi, IJI SA, 2011.
  • Dean Leffingwell, Don Widrig, Yazılım Gereksinimlerini Yönetme: Bir Kullanım Alanı Yaklaşımı, Addison-Wesley Professional. 7 Aralık 2012.
  • Kulak, Daryl ve Eamonn Guiney. Kullanım durumları: bağlamdaki gereksinimler. Addison-Wesley, 2012.
  • Meyer, Bertrand. Nesneye Yönelik Yazılım Yapısı. (2. Baskı). Prentice Hall, 2000.
  • Schneider, Geri ve Winters, Jason P. Kullanım Örneklerini Uygulama 2. Baskı: Pratik Bir Kılavuz. Addison-Wesley, 2001.
  • Wazlawick, Raul S. Bilgi Sistemleri için Nesneye Dayalı Analiz ve Tasarım: UML, OCL ve IFML ile Modelleme. Morgan Kaufmann, 2014.

Dış bağlantılar