No edit summary |
m ((username removed) (log details removed): Moving to Training namespace) |
||
(One intermediate revision by one other user not shown) | |||
Line 1: | Line 1: | ||
If UML or other structured ways to define system gist were forbidden – what would happen then? Maybe UML need not be forbidden – the effect would be the same if UML simply | If UML or other structured ways to define system gist were forbidden – what would happen then? Maybe UML need not be forbidden – the effect would be the same if UML simply were not used. | ||
Well, the system gist still exists – even if it is not explicitly documented. It must be extractable from the source code of any running system since the system is a transformation of the system gist no matter how that gist was captured in the first place. | Well, the system gist still exists – even if it is not explicitly documented. It must be extractable from the source code of any running system since the system is a transformation of the system gist, no matter how that gist was captured in the first place. | ||
Maybe the system gist is held in documents | Maybe the system gist is held in documents outlining requirements or prose text that describes scenarios the system should solve or support. Maybe the developers were obligated to write other prose documents that act as the documentation of the produced software. | ||
Documenting software is boring compared to coding for any developer. Code can be compiled and type-checked so that bugs | Documenting software is boring compared to coding for any developer. Code can be compiled and type-checked so that the bugs can be removed. Code can also be executed and further tested to ensure that the ideas we wanted to cover are covered. Documentation does not work that way. | ||
Most likely any existing documentation is filled with bugs beyond belief since the process | Most likely, any existing documentation is filled with bugs beyond belief since the verification process lacks compilation and testing. Since developers suspect this, developers seldom trust and consult the documentation of existing software systems. Instead, they tend to go to code. If the only option is prose documents, they are probably correct. Even if the developer finds information in the code – it is important to remember that the code is just the original developer’s interpretation of the requirement – and this need not be equal to the requirement. Software tools and libraries may follow other rules, but, when an experienced developer is confronted with a software system, they very seldom expect that the documentation is complete or correct. | ||
Prose documentation of system-gist is, for the reasons stated above, rarely used for anything except making the stakeholders feel a bit safe – like life jackets on an airliner that flies over land | Prose documentation of system-gist is, for the reasons stated above, rarely used for anything except making the stakeholders feel a bit safe – like life jackets on an airliner that flies over land. It was never intended to help anyone, but the stakeholders want it so we provide it. | ||
Another way I have come across to protect and keep the know-how that is the system gist is what I would describe as “invest in the team”. | Another way I have come across to protect and keep the know-how that is the system gist is what I would describe as “invest in the team”. | ||
Line 15: | Line 15: | ||
Let skilled and motivated software developers solve things with their talent and memory. Let the collective team memory be your know-how and documentation of the system gist. | Let skilled and motivated software developers solve things with their talent and memory. Let the collective team memory be your know-how and documentation of the system gist. | ||
This is the common way for most businesses that produce software that I have come across. I argue that this is not a strategy. It is an abdication of ownership and control. Developers might not see this as a problem at first since they take pride in the trust management places in them. | This is the common way for most businesses that produce software that I have come across. I argue that this is not a strategy. It is an abdication of ownership and control. Developers might not see this as a problem, at first, since they take pride in the trust management places in them. | ||
Still, I have seen many cases where this strategy | Still, I have seen many cases over the years where this strategy created a chasm between the ones that know (developers) and the ones that make decisions (management). It usually ends with a collapse that benefits no one. Since developers are now left on their own to decide where the resources should go – into system gist or modernity or maybe into fashion, they will soon lose the management's trust since management lacks control and does not understand why the developers chose to prioritize the way they do. | ||
Nevertheless, this is commonly how small and midsized businesses handle their software investments today. Let the code speak for itself – there is no other representation of the ideas within the software than the code itself. The | Nevertheless, this is commonly how small and midsized businesses handle their software investments today. Let the code speak for itself – there is no other representation of the ideas within the software than the code itself. The same code strongly flavored by the team members takes on what is modern and what is fashionable this year – or was last year. | ||
See: [[Luckily UML is Not Forbidden]] | See: [[Luckily UML is Not Forbidden]] | ||
[[Category:The MDriven Book]] | [[Category:The MDriven Book]] |
Latest revision as of 21:31, 20 December 2023
If UML or other structured ways to define system gist were forbidden – what would happen then? Maybe UML need not be forbidden – the effect would be the same if UML simply were not used.
Well, the system gist still exists – even if it is not explicitly documented. It must be extractable from the source code of any running system since the system is a transformation of the system gist, no matter how that gist was captured in the first place.
Maybe the system gist is held in documents outlining requirements or prose text that describes scenarios the system should solve or support. Maybe the developers were obligated to write other prose documents that act as the documentation of the produced software.
Documenting software is boring compared to coding for any developer. Code can be compiled and type-checked so that the bugs can be removed. Code can also be executed and further tested to ensure that the ideas we wanted to cover are covered. Documentation does not work that way.
Most likely, any existing documentation is filled with bugs beyond belief since the verification process lacks compilation and testing. Since developers suspect this, developers seldom trust and consult the documentation of existing software systems. Instead, they tend to go to code. If the only option is prose documents, they are probably correct. Even if the developer finds information in the code – it is important to remember that the code is just the original developer’s interpretation of the requirement – and this need not be equal to the requirement. Software tools and libraries may follow other rules, but, when an experienced developer is confronted with a software system, they very seldom expect that the documentation is complete or correct.
Prose documentation of system-gist is, for the reasons stated above, rarely used for anything except making the stakeholders feel a bit safe – like life jackets on an airliner that flies over land. It was never intended to help anyone, but the stakeholders want it so we provide it.
Another way I have come across to protect and keep the know-how that is the system gist is what I would describe as “invest in the team”.
Let skilled and motivated software developers solve things with their talent and memory. Let the collective team memory be your know-how and documentation of the system gist.
This is the common way for most businesses that produce software that I have come across. I argue that this is not a strategy. It is an abdication of ownership and control. Developers might not see this as a problem, at first, since they take pride in the trust management places in them.
Still, I have seen many cases over the years where this strategy created a chasm between the ones that know (developers) and the ones that make decisions (management). It usually ends with a collapse that benefits no one. Since developers are now left on their own to decide where the resources should go – into system gist or modernity or maybe into fashion, they will soon lose the management's trust since management lacks control and does not understand why the developers chose to prioritize the way they do.
Nevertheless, this is commonly how small and midsized businesses handle their software investments today. Let the code speak for itself – there is no other representation of the ideas within the software than the code itself. The same code strongly flavored by the team members takes on what is modern and what is fashionable this year – or was last year.