-
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
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- 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
Najnowsze wątki
- 2025-02-06 PROGRAM DOPŁAT DO AUT ELEKTRYCZNYCH TO ABSURD. ZA ŚRODKI Z KPO KUPIMY NIEMIECKIE I CHIŃSKIE AUTA
- 2025-02-05 ceny OC
- 2025-02-05 Re: ceny OC
- 2025-02-05 Re: ceny OC
- 2025-02-07 Smar do video
- 2025-02-06 Litowe baterie AA Li/FeS2 a alkaliczne
- 2025-02-07 Gliwice => Business Development Manager - Network and Network Security
- 2025-02-07 Warszawa => System Architect (Java background) <=
- 2025-02-07 Warszawa => System Architect (background deweloperski w Java) <=
- 2025-02-07 Warszawa => Solution Architect (Java background) <=
- 2025-02-07 Gliwice => Ekspert IT (obszar systemów sieciowych) <=
- 2025-02-07 Lublin => Programista Delphi <=
- 2025-02-07 Warszawa => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2025-02-07 Dęblin => Node.js / Fullstack Developer <=
- 2025-02-07 Bieruń => Spedytor Międzynarodowy (handel ładunkami/prowadzenie flo