-
Data: 2019-09-04 23:49:48
Temat: Re: Jak to robią w NASA
Od: Maciej Sobczak <s...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]> Asercje są formą komentarza, który dodatkowo można zweryfikować.
Kupa różnych narzędzi weryfikuje adnotacje zaszyte w komentarzach. Statycznie. I tak
powinno być.
> Asercja to postawa propozycjonalna.
Możliwe, że pomyliłeś grupy.
> Możesz sobie napisać
> #define assert(x) do {} while(0)
Nie, nie mogę. Zabrania tego zarówno MISRA-C jak i AUTOSAR.
Byłoby łatwiej, gdybyś nie spekulował.
> Asercje też są istotne dla czytelności.
Oczywiście. Ale stanowią dead-code, którego się unika z innych powodów. Być może te
powody nie są istotne jak się pisze coś innego gdzieś indziej, ale jeśli mówimy o
systemach krytycznych (taki wątek się zrobił), to obowiązują pewne reguły. Dużo
reguł. Więcej, niż gdzie indziej. W sumie właśnie od tego spostrzeżenia się ta
dyskusja wzięła.
> Asercja nie jest pojęciem wprowadzonym przez standard C.
Standard C definiuje dokładnie, co to pojęcie oznacza w języku C. Może gdzieś indziej
oznacza coś innego, albo nawet wcześniej. Nie ma to znaczenia.
> > Oczywiście możesz sobie wyobrazić (albo nawet mieć) narzędzie, któro statycznie
skanuje kod i sprawdza asercje (efektywnie traktując je jako static_assert), ale
takie narzędzie potrafi też wyłuskać adnotacje z komentarzy.
>
> ?
Ale czego nie rozumiesz? Której części?
> No to nie dość, że sam błędnie rozumiesz, to jeszcze próbujesz to swoje błędne
rozumienie promować.
Dopóki moje rozumienie opiera się na standardach (i to kilku), to będę je promował.
Nie do mnie pretensje, nie ja te standardy pisałem.
> A skrypty testowe to nie kod?
Nie musi być. Może to być procedura opisana słownie. Np. w Wordzie. Nie, nie nabijam
się. Nieprzypadkiem napisałem wcześniej, że w tej branży klepanie kodu to tylko kilka
procent wysiłku.
Natomiast nawet jeśli skrypt testowy będzie kodem w jakimś języku programowania,
nawet w tym samym (rzadki przypadek), to tego kodu nie obowiązują takie reguły, jak
te dotyczące właściwego kodu programu. Bo i po co.
Dlatego współcześnie popularnym przypadkiem jest użycie Pythona do pisania testów.
Tam sobie możesz (a nawet powinieneś) robić asercje ile wlezie.
--
Maciej Sobczak * http://www.inspirel.com
Następne wpisy z tego wątku
- 05.09.19 09:20 M.M.
- 05.09.19 13:37 M.M.
- 06.09.19 07:31 AK
- 06.09.19 10:12 M.M.
- 06.09.19 10:33 Mateusz Viste
- 06.09.19 12:06 M.M.
- 06.09.19 12:57 Mateusz Viste
- 06.09.19 15:42 Maciej Sobczak
- 06.09.19 16:06 Mateusz Viste
- 06.09.19 17:06 AK
- 06.09.19 17:11 AK
- 06.09.19 18:22 M.M.
- 06.09.19 18:29 g...@g...com
- 06.09.19 19:14 g...@g...com
- 06.09.19 20:28 M.M.
Najnowsze wątki z tej grupy
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
Najnowsze wątki
- 2024-05-20 Fiat 125p wer. pikup - w PRL moszna było, w III Reczy [pospolitej] nie moszna
- 2024-05-19 Pożar salonu z chińskimi elektrykami
- 2024-05-18 LED
- 2024-05-19 ceny nieruchomości
- 2024-05-18 Szczecin => UX/UI Designer <=
- 2024-05-18 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-18 Warszawa => Software .Net Developer <=
- 2024-05-18 Warszawa => Mid/Senior QA Engineer <=
- 2024-05-18 Ulm => Solution Architect (sichere Kommunikation und IoT-Loesungen <=
- 2024-05-18 Katowice => Head of Virtualization Platform Management and Operating S
- 2024-05-18 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-18 Wrocław => Consultant/Implementer Comarch ERP XL <=
- 2024-05-18 Gdańsk => Head of International Freight Forwarding Department <=
- 2024-05-18 Warszawa => Account Manager (Recruitment Services) <=
- 2024-05-18 Łódź => Salesperson - CRM Systems <=