Bootcamp:Chapter 9
No edit summary
(Step 294 Noticed code was lacking, added it for this step)
(42 intermediate revisions by 4 users not shown)
Line 1: Line 1:
This is Chapter 9. Here is the first part: [[The 1000 steps program to MDriven]], [[The 1000 steps program to MDriven Chapter 8|Chapter 8 (the previous chapter)]]
{{Edited|July|12|2025}}
<message>Write the content here to display this box</message>
This is '''Chapter 9'''. Here is the first part, [[Training:Bootcamp:Chapter 1|Chapter 1]], or see [[Training:Bootcamp:Chapter 8|Chapter 8 (the previous chapter)]]


You can find the video here: https://youtu.be/MPqx5af3QCM
=== '''Video 9: Inheritance and Statemachines''' ===
<html>


'''Video 9: MDrivenEducationVideo - Chapter 9: Inheritance and Statemachines'''
<p class="video-warn">
  To make your experience smooth, we set the main tags mentioned in the video to the right bar menu of this mini-player. Choose an interesting subtitle on the list and immediately get to the exact theme navigation item place in the video. Now you can pick any topic to be instructed on without watching the whole video.
</p>


{| class="wikitable"
<div class="video">
|Title
  <div class="video__wrapper">
|Content
    <iframe src="https://www.youtube.com/embed/MPqx5af3QCM?si=7WCEfSXr41UjuDTI" title="YouTube video player" frameborder="0" allowfullscreen></iframe>
|Time(segment start)
  </div>
|-
  <div class="video__navigation">
|Introduction
<span data-video="MPqx5af3QCM" data-start="00" tabindex="0"> <strong> Steps 265 - 301 </strong> </span>
|Introduction
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="00" tabindex="0"> Introduction </span>
|00:00
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="27" tabindex="0"> Aligning items </span>
|-
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="322" tabindex="0"> Inheritance </span>
|Aligning items
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="870" tabindex="0"> Abstract classes </span>
|How to align Items in the ViewModels
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="1230" tabindex="0"> Repetition </span>
|00:27
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="1647" tabindex="0"> Statemachines </span>
|-
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="1845" tabindex="0"> Triggers and entry </span>
|Inheritance
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="2250" tabindex="0"> Guards </span>
|Generalization mode, inheritance, superclasses, subclasses
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="2883" tabindex="0"> Class actions for triggers </span>
|05:22
    <span class="navigation-item" data-video="MPqx5af3QCM" data-start="3041" tabindex="0"> Web application example </span>
|-
  </div>
|Abstract classes
</div>
|Abstract classes
|14:30
|-
|Repetition
|More inheritance/repetition
|20:30
|-
|Statemachines
|Statemachines intro, states
|27:27
|-
|Triggers and entry
|Statemachines, triggers, and entry actions
|30:45
|-
|Guards
|Statemachines, guards
|37:30
|-
|Class actions for triggers
|Statemachines, Class actions for triggers
|48:03
|-
|Webapplication example
|Showing statemachines in the webapplication
|50:41
|}


In this chapter we introduce UML inheritance and UML state-machines
</html>


==== Chapter 9, Inheritance and statemachines ====
== Chapter 9: Inheritance and Statemachines ==
265 Remove the 20pixel marging on the buttons and apply Align Items property End instead to make everything end up at the bottom line
'''In this chapter, we introduce [[Training:UML Inheritance|UML inheritance]] and [[Training:UML – State machines|UML Statemachines]].'''


266 Test out combinations of Justify content and Align Items, and direction to familiarize yourself with ways to control flow of UI-widgets
265. Remove the 20-pixel margin on the buttons and apply the Align Items property end instead, to make everything end up on the bottom line.


267 Introduce the new class CarDealer
266. Test out combinations of Justify content and Align Items, and determine how to familiarize yourself with ways to control the flow of UI widgets.


268 Introduce the new class CarOwner
267. Introduce the new class '''CarDealer'''.


269 Add generalization arrows from CarDealer to CarOwner and from Person to CarOwner
268. Introduce the new class '''CarOwner'''.


270 Add the Attribute Name:String to CarOwner and save - notif the error . make sure you understand why Name is reported as doublet - fix by remove name of Person
269. Add generalization arrows from '''CarDealer''' to '''CarOwner''' and from '''Person''' to '''CarOwner'''.


271 Make sure you understand Subclass and Super class - look up these aericles on the wiki <nowiki>https://wiki.mdriven.net/index.php/UML_Inheritance</nowiki> <nowiki>https://wiki.mdriven.net/index.php/UML_School#Lesson_3:_UML_Inheritance</nowiki>
270. Add the Attribute <code><span class="col-black">'''Name:String'''</span></code> to '''CarOwner''' and save.
* Notice the error.
* Make sure you understand why '''Name''' is reported as a doublet.
* Fix it by removing '''Name of Person'''.  
271. Move the multi-link association existing between the classes '''Car''' and '''Person''' (The one with the '''HistoricOwnership''' association class) to '''Car''' and '''CarOwner'''.  


272 Add new association from CarOwner to Car - name the Cars end CurrentlyOwnedCars
* Rename the '''Car''' association end from '''CarsPersonUsedToOwn''' to '''CarsOwnerUsedToOwn''' and apply changes.
* Notice the errors.
* Create and refresh autoforms to correct the errors.
* Select the class '''CarOwner''' and mark it as Abstract by going to the Property Inspector and selecting '''True''' from the '''IsAbstract''' dropdown. Notice now that the label on the '''CarOwner''' Class is now in italics.


273 Delete the old link with currently owned car, update autoforms save and check errors
Make sure you understand Subclass and Superclass. Look up and read through this article on the Wiki:
* [[Training:UML Inheritance|UML_Inheritance]]
272. Add a new association from '''CarOwner''' to '''Car'''. Name the '''Car''' end as '''CurrentlyOwnedCars'''.


274 delete the combobox that showed the now removed currently owned car in the Person form
273. Delete the old link with the currently owned car. Update the autoforms. Save and check for errors. 


275 Add new class CarTransferOwnershipDocument, new association from Car(0..1) to CarTransferOwnershipDocument(*)
274. Delete the Combobox that showed the now-removed currently owned car in the '''Person''' form.


276 Add Association from CarOwner to CarTransferOwnershipDocument, call link DocumentsForSales(*) and Seller(0..1)
275. Add a new class: '''CarTransferOwnershipDocument''', and add a new association from <code><span class="col-black">'''Car(0..1)'''</span></code> to <code><span class="col-black">'''CarTransferOwnershipDocument(*)'''</span></code>


277 Add another Association from CarOwner to CarTransferOwnershipDocument, call link DocumentsForPurchase(*) and Buyer(0..1)
276. Add an association from '''CarOwner''' to '''CarTransferOwnershipDocument'''. Call the link <code><span class="col-black">'''DocumentsForSales(*)'''</span></code> and <code><span class="col-black">'''Seller(0..1)'''</span></code>


278 Add CarFactory and make it subclass to CarOwner
277. Add another association from '''CarOwner''' to '''CarTransferOwnershipDocument'''. Call the link <code><span class="col-black">'''DocumentsForPurchase(*)'''</span></code> and <code><span class="col-black">'''Buyer(0..1)'''</span></code>


279 Add ScrapYard and make it subclass to CarOwner
278. Add '''CarFactory''' and make it a subclass of '''CarOwner'''.


280 Add a State machine on Class Car
279. Add '''ScrapYard''' and make it a subclass of '''CarOwner'''.


281 Add a State in the statemachine of the car called BrandNew
280. Add a statemachine on Class '''Car'''.


282 Add another state InOwnershipTransaction
281. Add a state in the statemachine of the car called '''BrandNew'''.


283 Add a Transition arrow from BrandNew to InOwnershipTransaction
282. Add another state: '''InOwnershipTransaction'''.


284 Call the trigger of the transition InitiateSale
283. Add a Transition arrow from '''BrandNew''' to '''InOwnershipTransaction'''.


285 Add yet another state called OwnershipStable
284. Call the trigger of the transition '''InitiateSale'''.


286 Add a transition from InOwnershipTransaction to OwnershipStable, name the trigger CloseSale
285. Add yet another state called '''OwnershipStable'''.


287 Add a transition from OwnershipStable to InOwnershipTransaction, reuse the trigger InitiateSale on this transition
286. Add a transition from '''InOwnershipTransaction''' to '''OwnershipStable'''. Name the trigger '''CloseSale'''.


288 Create an Entry Action in state InOwnerShipTransaction, create a CarTransferOwnershipDocument and add it to the cars list of CarTransferOwnershipDocuments, also assign the seller of the new CarTransferOwnershipDocument to the current owner of the Car
287. Add a transition from '''OwnershipStable''' to '''InOwnershipTransaction'''. Reuse the trigger '''InitiateSale''' on this transition.


289 Add a an association from CarTransferOwnershipDocument to Car, call the single end CurrentTransaction - set the Cars end to not Navigable
288. Create an <u>Entry Action</u> in the state '''InOwnerShipTransaction'''. 


290 In the Entry Action in state InOwnerShipTransaction assignmen the CurrentTransation to the created document
* Click the '''InOwnerShipTransaction''' state to highlight it's Properties.
* In the Property Inspector click the three dots at the '''Entry''' Property to access the Action Editor Entry for '''InOwnerShipTransaction'''.
* Type the following Expression:
<syntaxhighlight>
let doc=CarTransferOwnershipDocument.Create in
(
self.CarTransferOwnershipDocuments.Add(doc);
doc.Seller:=self.CarOwner
)
</syntaxhighlight>The Expression above:  


291 Go to Guard of CloseSale - and check the currentTransation has a Buyer
* Creates a <code><span class="col-black">'''CarTransferOwnershipDocument'''</span></code> and adds it to the cars list of '''CarTransferOwnershipDocuments'''.


292 In the OwnershipStable add an Entry action that removes the car from seller currentlyownedcars and add it to the buyer currentlyownedcars
* Also, assigns the '''Seller''' of the new '''CarTransferOwnershipDocument''' to the current owner of the '''Car'''.
289. Add an association from '''CarTransferOwnershipDocumen'''t to '''Car'''. Call the single-end '''CurrentTransaction'''. Set the Car's end to '''not Navigable'''.


293 In the OwnershipStable add an Entry action  add an update of the sellers CarsOwnerUsedToOwn
290. In the Entry Action, in the state '''InOwnerShipTransaction''', assign the '''CurrentTransaction''' to the created document.


294 On the transition between BrandNew and InOwnerShipTransaction add a guaurd that check that there is a CarOwner
* Type the following Expression to achieve this :
<syntaxhighlight>
let doc=CarTransferOwnershipDocument.Create in
(
self.CarTransferOwnershipDocuments.Add(doc);
doc.Seller:=self.CarOwner;
self.CurrentTransaction:=doc
)


295 On the InitiateSale trigger - add a ClassAction for trigger


296 On the CloseSale trigger - add a ClassAction for trigger
</syntaxhighlight>


297 Refresh the AutoForms
291. Go to Guard of CloseSale and check that the current transaction has a '''Buyer'''.


298 Save and test on the web, Create a CarFactory, call it BWM in Munich, Add a Car to this CarFactory
* Type the following Expression into the Guard OCL Editor to achieve this :


299 Initiate the Sale, check that you get a CarTransferOwnershipDocument
<code>self.CurrentTransaction.Buyer->notempty</code>


300 Assign a buyer in the CarTransferOwnershipDocument, then close the sale, check that owner is switched
292. In the '''OwnershipStable''', add an Entry action that removes the '''Car''' from '''Seller'''<nowiki/>'s '''CurrentlyOwnedCars''' and adds it to the '''Buyer'''<nowiki/>'s '''CurrentlyOwnedCars'''.


301 Set the default representation of CarOwner to self.Name
* Type the following Expression to achieve this :
<syntaxhighlight>
self.CurrentTransaction.Seller.CurrentlyOwnedCars.Remove(self);
self.CurrentTransaction.Buyer.CurrentlyOwnedCars.Add(self)


[[The 1000 steps program to MDriven Chapter 10|Chapter 10]]
</syntaxhighlight>293. In the '''OwnershipStable''', add an Entry action and add an update of the '''Seller'''<nowiki/>'s '''CarsOwnerUsedToOwn'''.
[[Category:1000 Steps Program]]
 
* Update the previous Expression in step 292 as provided below :
<syntaxhighlight>
self.CurrentTransaction.Seller.CurrentlyOwnedCars.Remove(self);
self.CurrentTransaction.Buyer.CurrentlyOwnedCars.Add(self);
self.CurrentTransaction.Seller.CarsOwnerUsedToOwn.Add(self)
 
</syntaxhighlight>294. On the transition between '''BrandNew''' and '''InOwnerShipTransaction''', add a guard that checks that there is a '''CarOwner'''.
 
* Type the following Expression into the OCL Editor '''Guard BrandNew'''->'''InOwnershipTransaction''' to achieve this:
 
<code>self.CarOwner->notempty</code>
 
295. On the InitiateSale trigger, add a '''ClassAction''' for the trigger.
 
296. On the CloseSale trigger, add a '''ClassAction''' for the trigger.
 
297. Refresh the AutoForms.
 
298. Save and test on the web.
* Create a '''CarFactory'''.
* Call it '''BMW''' in '''Munich'''.
* Add a '''Car''' to this '''CarFactory'''.
299. Initiate the Sale and check that you get a '''CarTransferOwnershipDocument'''.
 
300. Assign a buyer in the '''CarTransferOwnershipDocument''', then close the Sale. Check that ownership has switched.
 
301. Set the default representation of '''CarOwner''' to <code><span class="col-black">'''self.Name'''</span></code>
 
=== '''Next Chapter''' ===
[[Training:Bootcamp:Chapter 10|Bootcamp:Chapter 10]]
[[Category:Bootcamp]]

Revision as of 22:52, 25 March 2025

This page was created by Hans.karlsen@mdriven.net on 2022-10-23. Last edited by Stephanie@mdriven.net on 2025-04-03.


This is Chapter 9. Here is the first part, Chapter 1, or see Chapter 8 (the previous chapter)

Video 9: Inheritance and Statemachines

To make your experience smooth, we set the main tags mentioned in the video to the right bar menu of this mini-player. Choose an interesting subtitle on the list and immediately get to the exact theme navigation item place in the video. Now you can pick any topic to be instructed on without watching the whole video.

Steps 265 - 301 Introduction Aligning items Inheritance Abstract classes Repetition Statemachines Triggers and entry Guards Class actions for triggers Web application example

Chapter 9: Inheritance and Statemachines

In this chapter, we introduce UML inheritance and UML Statemachines.

265. Remove the 20-pixel margin on the buttons and apply the Align Items property end instead, to make everything end up on the bottom line.

266. Test out combinations of Justify content and Align Items, and determine how to familiarize yourself with ways to control the flow of UI widgets.

267. Introduce the new class CarDealer.

268. Introduce the new class CarOwner.

269. Add generalization arrows from CarDealer to CarOwner and from Person to CarOwner.

270. Add the Attribute Name:String to CarOwner and save.

  • Notice the error.
  • Make sure you understand why Name is reported as a doublet.
  • Fix it by removing Name of Person.

271. Move the multi-link association existing between the classes Car and Person (The one with the HistoricOwnership association class) to Car and CarOwner.

  • Rename the Car association end from CarsPersonUsedToOwn to CarsOwnerUsedToOwn and apply changes.
  • Notice the errors.
  • Create and refresh autoforms to correct the errors.
  • Select the class CarOwner and mark it as Abstract by going to the Property Inspector and selecting True from the IsAbstract dropdown. Notice now that the label on the CarOwner Class is now in italics.

Make sure you understand Subclass and Superclass. Look up and read through this article on the Wiki:

272. Add a new association from CarOwner to Car. Name the Car end as CurrentlyOwnedCars.

273. Delete the old link with the currently owned car. Update the autoforms. Save and check for errors.

274. Delete the Combobox that showed the now-removed currently owned car in the Person form.

275. Add a new class: CarTransferOwnershipDocument, and add a new association from Car(0..1) to CarTransferOwnershipDocument(*)

276. Add an association from CarOwner to CarTransferOwnershipDocument. Call the link DocumentsForSales(*) and Seller(0..1)

277. Add another association from CarOwner to CarTransferOwnershipDocument. Call the link DocumentsForPurchase(*) and Buyer(0..1)

278. Add CarFactory and make it a subclass of CarOwner.

279. Add ScrapYard and make it a subclass of CarOwner.

280. Add a statemachine on Class Car.

281. Add a state in the statemachine of the car called BrandNew.

282. Add another state: InOwnershipTransaction.

283. Add a Transition arrow from BrandNew to InOwnershipTransaction.

284. Call the trigger of the transition InitiateSale.

285. Add yet another state called OwnershipStable.

286. Add a transition from InOwnershipTransaction to OwnershipStable. Name the trigger CloseSale.

287. Add a transition from OwnershipStable to InOwnershipTransaction. Reuse the trigger InitiateSale on this transition.

288. Create an Entry Action in the state InOwnerShipTransaction.

  • Click the InOwnerShipTransaction state to highlight it's Properties.
  • In the Property Inspector click the three dots at the Entry Property to access the Action Editor Entry for InOwnerShipTransaction.
  • Type the following Expression:
let doc=CarTransferOwnershipDocument.Create in
(
self.CarTransferOwnershipDocuments.Add(doc);
doc.Seller:=self.CarOwner
)

The Expression above:  

  • Creates a CarTransferOwnershipDocument and adds it to the cars list of CarTransferOwnershipDocuments.
  • Also, assigns the Seller of the new CarTransferOwnershipDocument to the current owner of the Car.

289. Add an association from CarTransferOwnershipDocument to Car. Call the single-end CurrentTransaction. Set the Car's end to not Navigable.

290. In the Entry Action, in the state InOwnerShipTransaction, assign the CurrentTransaction to the created document.

  • Type the following Expression to achieve this :
let doc=CarTransferOwnershipDocument.Create in
(
self.CarTransferOwnershipDocuments.Add(doc);
doc.Seller:=self.CarOwner;
self.CurrentTransaction:=doc
)

291. Go to Guard of CloseSale and check that the current transaction has a Buyer.

  • Type the following Expression into the Guard OCL Editor to achieve this :

self.CurrentTransaction.Buyer->notempty

292. In the OwnershipStable, add an Entry action that removes the Car from Seller's CurrentlyOwnedCars and adds it to the Buyer's CurrentlyOwnedCars.

  • Type the following Expression to achieve this :
self.CurrentTransaction.Seller.CurrentlyOwnedCars.Remove(self);
self.CurrentTransaction.Buyer.CurrentlyOwnedCars.Add(self)

293. In the OwnershipStable, add an Entry action and add an update of the Seller's CarsOwnerUsedToOwn.

  • Update the previous Expression in step 292 as provided below :
self.CurrentTransaction.Seller.CurrentlyOwnedCars.Remove(self);
self.CurrentTransaction.Buyer.CurrentlyOwnedCars.Add(self);
self.CurrentTransaction.Seller.CarsOwnerUsedToOwn.Add(self)

294. On the transition between BrandNew and InOwnerShipTransaction, add a guard that checks that there is a CarOwner.

  • Type the following Expression into the OCL Editor Guard BrandNew->InOwnershipTransaction to achieve this:

self.CarOwner->notempty

295. On the InitiateSale trigger, add a ClassAction for the trigger.

296. On the CloseSale trigger, add a ClassAction for the trigger.

297. Refresh the AutoForms.

298. Save and test on the web.

  • Create a CarFactory.
  • Call it BMW in Munich.
  • Add a Car to this CarFactory.

299. Initiate the Sale and check that you get a CarTransferOwnershipDocument.

300. Assign a buyer in the CarTransferOwnershipDocument, then close the Sale. Check that ownership has switched.

301. Set the default representation of CarOwner to self.Name

Next Chapter

Bootcamp:Chapter 10