ceedling 0.19.0 → 0.20.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Rakefile +10 -10
- data/bin/ceedling +205 -92
- data/ceedling-0.19.0.gem +0 -0
- data/config/test_environment.rb +12 -12
- data/docs/CeedlingPacket.md +866 -853
- data/docs/CeedlingPacket.odt +0 -0
- data/docs/CeedlingPacket.pdf +0 -0
- data/examples/temp_sensor/rakefile.rb +4 -4
- data/examples/temp_sensor/src/AdcConductor.c +42 -42
- data/examples/temp_sensor/src/AdcConductor.h +13 -13
- data/examples/temp_sensor/src/AdcHardware.c +27 -27
- data/examples/temp_sensor/src/AdcHardware.h +11 -11
- data/examples/temp_sensor/src/AdcHardwareConfigurator.c +18 -18
- data/examples/temp_sensor/src/AdcHardwareConfigurator.h +10 -10
- data/examples/temp_sensor/src/AdcModel.c +33 -33
- data/examples/temp_sensor/src/AdcModel.h +13 -13
- data/examples/temp_sensor/src/AdcTemperatureSensor.c +51 -51
- data/examples/temp_sensor/src/AdcTemperatureSensor.h +10 -10
- data/examples/temp_sensor/src/Executor.c +25 -25
- data/examples/temp_sensor/src/Executor.h +9 -9
- data/examples/temp_sensor/src/IntrinsicsWrapper.c +18 -18
- data/examples/temp_sensor/src/IntrinsicsWrapper.h +7 -7
- data/examples/temp_sensor/src/Main.c +46 -46
- data/examples/temp_sensor/src/Main.h +7 -7
- data/examples/temp_sensor/src/Model.c +10 -10
- data/examples/temp_sensor/src/Model.h +8 -8
- data/examples/temp_sensor/src/ModelConfig.h +7 -7
- data/examples/temp_sensor/src/TaskScheduler.c +72 -72
- data/examples/temp_sensor/src/TaskScheduler.h +11 -11
- data/examples/temp_sensor/src/TemperatureCalculator.c +27 -27
- data/examples/temp_sensor/src/TemperatureCalculator.h +8 -8
- data/examples/temp_sensor/src/TemperatureFilter.c +38 -38
- data/examples/temp_sensor/src/TemperatureFilter.h +10 -10
- data/examples/temp_sensor/src/TimerConductor.c +15 -15
- data/examples/temp_sensor/src/TimerConductor.h +9 -9
- data/examples/temp_sensor/src/TimerConfigurator.c +51 -51
- data/examples/temp_sensor/src/TimerConfigurator.h +15 -15
- data/examples/temp_sensor/src/TimerHardware.c +15 -15
- data/examples/temp_sensor/src/TimerHardware.h +8 -8
- data/examples/temp_sensor/src/TimerInterruptConfigurator.c +55 -55
- data/examples/temp_sensor/src/TimerInterruptConfigurator.h +13 -13
- data/examples/temp_sensor/src/TimerInterruptHandler.c +25 -25
- data/examples/temp_sensor/src/TimerInterruptHandler.h +10 -10
- data/examples/temp_sensor/src/TimerModel.c +9 -9
- data/examples/temp_sensor/src/TimerModel.h +8 -8
- data/examples/temp_sensor/src/Types.h +90 -90
- data/examples/temp_sensor/src/UsartBaudRateRegisterCalculator.c +18 -18
- data/examples/temp_sensor/src/UsartBaudRateRegisterCalculator.h +8 -8
- data/examples/temp_sensor/src/UsartConductor.c +21 -21
- data/examples/temp_sensor/src/UsartConductor.h +7 -7
- data/examples/temp_sensor/src/UsartConfigurator.c +39 -39
- data/examples/temp_sensor/src/UsartConfigurator.h +13 -13
- data/examples/temp_sensor/src/UsartHardware.c +22 -22
- data/examples/temp_sensor/src/UsartHardware.h +9 -9
- data/examples/temp_sensor/src/UsartModel.c +34 -34
- data/examples/temp_sensor/src/UsartModel.h +10 -10
- data/examples/temp_sensor/src/UsartPutChar.c +16 -16
- data/examples/temp_sensor/src/UsartPutChar.h +8 -8
- data/examples/temp_sensor/src/UsartTransmitBufferStatus.c +7 -7
- data/examples/temp_sensor/src/UsartTransmitBufferStatus.h +8 -8
- data/examples/temp_sensor/test/TestAdcConductor.c +121 -121
- data/examples/temp_sensor/test/TestAdcHardware.c +44 -44
- data/examples/temp_sensor/test/TestAdcModel.c +33 -33
- data/examples/temp_sensor/test/TestExecutor.c +36 -36
- data/examples/temp_sensor/test/TestMain.c +24 -24
- data/examples/temp_sensor/test/TestModel.c +20 -20
- data/examples/temp_sensor/test/TestTaskScheduler.c +104 -104
- data/examples/temp_sensor/test/TestTemperatureCalculator.c +33 -33
- data/examples/temp_sensor/test/TestTemperatureFilter.c +79 -79
- data/examples/temp_sensor/test/TestTimerConductor.c +32 -32
- data/examples/temp_sensor/test/TestTimerHardware.c +26 -26
- data/examples/temp_sensor/test/TestTimerModel.c +18 -18
- data/examples/temp_sensor/test/TestUsartBaudRateRegisterCalculator.c +21 -21
- data/examples/temp_sensor/test/TestUsartConductor.c +40 -40
- data/examples/temp_sensor/test/TestUsartHardware.c +36 -36
- data/examples/temp_sensor/test/TestUsartModel.c +36 -36
- data/examples/temp_sensor/test/support/UnityHelper.c +12 -12
- data/examples/temp_sensor/test/support/UnityHelper.h +12 -12
- data/lib/ceedling/configurator_builder.rb +1 -1
- data/lib/ceedling/tasks_base.rake +10 -2
- data/lib/ceedling/tool_executor.rb +3 -0
- data/lib/ceedling/version.rb +3 -3
- data/license.txt +1 -1
- data/plugins/bullseye/bullseye.rake +162 -162
- data/plugins/gcov/gcov.rake +152 -152
- data/plugins/module_generator/lib/module_generator.rb +145 -145
- data/plugins/module_generator/module_generator.rake +14 -14
- data/plugins/stdout_gtestlike_tests_report/assets/template.erb +84 -0
- data/plugins/stdout_gtestlike_tests_report/assets/template.erb copy +59 -0
- data/plugins/stdout_gtestlike_tests_report/config/stdout_gtestlike_tests_report.yml +4 -0
- data/plugins/stdout_gtestlike_tests_report/lib/stdout_gtestlike_tests_report.rb +43 -0
- data/spec/system/deployment_spec.rb +0 -1
- data/test_graveyard/integration/paths_test.rb +80 -80
- data/test_graveyard/integration/rake_rules_aux_dependencies_test.rb +75 -75
- data/test_graveyard/integration/rake_rules_cmock_test.rb +74 -74
- data/test_graveyard/integration/rake_rules_preprocess_test.rb +178 -178
- data/test_graveyard/integration/rake_rules_test.rb +268 -268
- data/test_graveyard/integration/rake_tasks_test.rb +103 -103
- data/test_graveyard/integration_test_helper.rb +34 -34
- data/test_graveyard/rakefile_rules.rb +10 -10
- data/test_graveyard/rakefile_rules_aux_dependencies.rb +10 -10
- data/test_graveyard/rakefile_rules_cmock.rb +10 -10
- data/test_graveyard/rakefile_rules_preprocess.rb +10 -10
- data/test_graveyard/rakefile_tasks.rb +10 -10
- data/test_graveyard/system/file_system_test.rb +78 -78
- data/test_graveyard/system/project_mocks_test.rb +38 -38
- data/test_graveyard/system/project_simple_test.rb +39 -39
- data/test_graveyard/system/rule_mocks_test.rb +44 -44
- data/test_graveyard/system/rule_runners_test.rb +44 -44
- data/test_graveyard/system_test_helper.rb +73 -73
- data/test_graveyard/test_helper.rb +93 -93
- data/test_graveyard/unit/busted/configurator_builder_test.rb +569 -569
- data/test_graveyard/unit/busted/configurator_helper_test.rb +234 -234
- data/test_graveyard/unit/busted/configurator_test.rb +232 -232
- data/test_graveyard/unit/busted/configurator_validator_test.rb +169 -169
- data/test_graveyard/unit/busted/deep_merge_fix_test.rb +55 -55
- data/test_graveyard/unit/busted/dependinator_test.rb +129 -129
- data/test_graveyard/unit/busted/file_finder_helper_test.rb +45 -45
- data/test_graveyard/unit/busted/file_finder_test.rb +114 -114
- data/test_graveyard/unit/busted/file_path_utils_test.rb +97 -97
- data/test_graveyard/unit/busted/file_system_utils_test.rb +21 -21
- data/test_graveyard/unit/busted/generator_test.rb +187 -187
- data/test_graveyard/unit/busted/generator_test_results_test.rb +129 -129
- data/test_graveyard/unit/busted/generator_test_runner_test.rb +475 -475
- data/test_graveyard/unit/busted/preprocessinator_file_handler_test.rb +39 -39
- data/test_graveyard/unit/busted/preprocessinator_helper_test.rb +156 -156
- data/test_graveyard/unit/busted/preprocessinator_includes_handler_test.rb +93 -93
- data/test_graveyard/unit/busted/preprocessinator_test.rb +57 -57
- data/test_graveyard/unit/busted/project_file_loader_test.rb +142 -142
- data/test_graveyard/unit/busted/setupinator_test.rb +45 -45
- data/test_graveyard/unit/busted/streaminator_test.rb +49 -49
- data/test_graveyard/unit/busted/task_invoker_test.rb +69 -69
- data/test_graveyard/unit/busted/test_includes_extractor_test.rb +111 -111
- data/test_graveyard/unit/busted/test_invoker_helper_test.rb +62 -62
- data/test_graveyard/unit/busted/test_invoker_test.rb +47 -47
- data/test_graveyard/unit/busted/tool_executor_helper_test.rb +100 -100
- data/test_graveyard/unit/busted/tool_executor_test.rb +351 -351
- data/test_graveyard/unit/busted/verbosinator_test.rb +65 -65
- data/test_graveyard/unit/preprocessinator_extractor_test.rb +731 -731
- data/test_graveyard/unit_test_helper.rb +16 -16
- data/vendor/c_exception/LICENSE.txt +30 -30
- data/vendor/c_exception/README.md +11 -1
- data/vendor/c_exception/docs/CExceptionSummary.odt +0 -0
- data/vendor/c_exception/docs/CExceptionSummary.pdf +0 -0
- data/vendor/c_exception/docs/readme.txt +261 -242
- data/vendor/c_exception/lib/CException.c +46 -46
- data/vendor/c_exception/lib/CException.h +110 -86
- data/vendor/c_exception/makefile +23 -23
- data/vendor/c_exception/test/CExceptionConfig.h +46 -46
- data/vendor/c_exception/test/TestException.c +391 -342
- data/vendor/c_exception/test/TestException_Runner.c +5 -12
- data/vendor/c_exception/vendor/unity/README.md +211 -0
- data/vendor/c_exception/vendor/unity/auto/colour_prompt.rb +1 -1
- data/vendor/c_exception/vendor/unity/auto/colour_reporter.rb +38 -38
- data/vendor/c_exception/vendor/unity/auto/generate_config.yml +36 -36
- data/vendor/c_exception/vendor/unity/auto/generate_module.rb +202 -202
- data/vendor/c_exception/vendor/unity/auto/generate_test_runner.rb +391 -320
- data/vendor/c_exception/vendor/unity/auto/parseOutput.rb +2 -0
- data/vendor/c_exception/vendor/unity/auto/stylize_as_junit.rb +260 -0
- data/vendor/c_exception/vendor/unity/auto/type_sanitizer.rb +8 -0
- data/vendor/c_exception/vendor/unity/auto/unity_test_summary.py +135 -0
- data/vendor/c_exception/vendor/unity/auto/unity_test_summary.rb +148 -139
- data/vendor/c_exception/vendor/unity/docs/Unity Summary.odt +0 -0
- data/vendor/c_exception/vendor/unity/docs/Unity Summary.pdf +0 -0
- data/vendor/c_exception/vendor/unity/docs/Unity Summary.txt +224 -216
- data/vendor/c_exception/vendor/unity/docs/license.txt +21 -31
- data/vendor/c_exception/vendor/unity/examples/example_1/makefile +40 -15
- data/vendor/c_exception/vendor/unity/examples/example_1/src/ProductionCode2.c +2 -0
- data/vendor/c_exception/vendor/unity/examples/example_1/test/test_runners/TestProductionCode2_Runner.c +32 -25
- data/vendor/c_exception/vendor/unity/examples/example_1/test/test_runners/TestProductionCode_Runner.c +29 -22
- data/vendor/c_exception/vendor/unity/examples/example_2/makefile +40 -14
- data/vendor/c_exception/vendor/unity/examples/example_2/src/ProductionCode2.c +2 -0
- data/vendor/c_exception/vendor/unity/examples/example_2/test/test_runners/all_tests.c +2 -2
- data/vendor/c_exception/vendor/unity/examples/example_3/rakefile.rb +0 -1
- data/vendor/c_exception/vendor/unity/examples/example_3/src/ProductionCode2.c +2 -0
- data/vendor/c_exception/vendor/unity/extras/fixture/rakefile.rb +48 -37
- data/vendor/c_exception/vendor/unity/extras/fixture/rakefile_helper.rb +179 -179
- data/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture.c +135 -94
- data/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture.h +13 -17
- data/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture_internals.h +12 -18
- data/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture_malloc_overrides.h +30 -0
- data/vendor/c_exception/vendor/unity/extras/fixture/test/Makefile +60 -0
- data/vendor/c_exception/vendor/unity/extras/fixture/test/main/AllTests.c +4 -3
- data/vendor/c_exception/vendor/unity/extras/fixture/test/{testunity_fixture.c → template_fixture_tests.c} +0 -0
- data/vendor/c_exception/vendor/unity/extras/fixture/test/unity_fixture_Test.c +182 -27
- data/vendor/c_exception/vendor/unity/extras/fixture/test/unity_fixture_TestRunner.c +13 -0
- data/vendor/c_exception/vendor/unity/extras/fixture/test/unity_output_Spy.c +8 -6
- data/vendor/c_exception/vendor/unity/extras/fixture/test/unity_output_Spy.h +2 -2
- data/vendor/c_exception/vendor/unity/release/build.info +1 -1
- data/vendor/c_exception/vendor/unity/release/version.info +1 -1
- data/vendor/c_exception/vendor/unity/src/unity.c +1333 -1145
- data/vendor/c_exception/vendor/unity/src/unity.h +290 -307
- data/vendor/c_exception/vendor/unity/src/unity_internals.h +758 -620
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_cmd.c +7 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_def.c +7 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_head1.c +55 -0
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_head1.h +15 -0
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_cmd.c +4 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_def.c +4 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_head1.c +75 -0
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_head1.h +13 -0
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_new1.c +6 -5
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_new2.c +4 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_param.c +4 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_run1.c +6 -5
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_run2.c +4 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_yaml.c +7 -6
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_new1.c +9 -5
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_new2.c +7 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_param.c +7 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_run1.c +9 -5
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_run2.c +7 -3
- data/vendor/c_exception/vendor/unity/test/expectdata/testsample_yaml.c +10 -6
- data/vendor/c_exception/vendor/unity/{rakefile.rb → test/rakefile} +60 -61
- data/vendor/c_exception/vendor/unity/{rakefile_helper.rb → test/rakefile_helper.rb} +255 -249
- data/vendor/c_exception/vendor/unity/test/targets/clang_file.yml +83 -0
- data/vendor/c_exception/vendor/unity/{targets → test/targets}/clang_strict.yml +83 -83
- data/vendor/c_exception/vendor/unity/test/targets/gcc_32.yml +49 -0
- data/vendor/c_exception/vendor/unity/test/targets/gcc_64.yml +50 -0
- data/vendor/c_exception/vendor/unity/{targets/gcc_64.yml → test/targets/gcc_auto_limits.yml} +46 -45
- data/vendor/c_exception/vendor/unity/test/targets/gcc_auto_sizeof.yml +47 -0
- data/vendor/c_exception/vendor/unity/test/targets/gcc_auto_stdint.yml +58 -0
- data/vendor/{cmock/vendor/c_exception/vendor/unity/targets/gcc_64.yml → c_exception/vendor/unity/test/targets/gcc_manual_math.yml} +46 -45
- data/vendor/{cmock/vendor/c_exception/vendor/unity → c_exception/vendor/unity/test}/targets/hitech_picc18.yml +101 -101
- data/vendor/{cmock/vendor/c_exception/vendor/unity → c_exception/vendor/unity/test}/targets/iar_arm_v4.yml +89 -89
- data/vendor/{cmock/vendor/c_exception/vendor/unity → c_exception/vendor/unity/test}/targets/iar_arm_v5.yml +79 -79
- data/vendor/c_exception/vendor/unity/{targets → test/targets}/iar_arm_v5_3.yml +79 -79
- data/vendor/{cmock/vendor/c_exception/vendor/unity → c_exception/vendor/unity/test}/targets/iar_armcortex_LM3S9B92_v5_4.yml +93 -93
- data/vendor/c_exception/vendor/unity/{targets → test/targets}/iar_cortexm3_v5.yml +83 -83
- data/vendor/{cmock/vendor/c_exception/vendor/unity → c_exception/vendor/unity/test}/targets/iar_msp430.yml +94 -94
- data/vendor/c_exception/vendor/unity/{targets → test/targets}/iar_sh2a_v6.yml +85 -85
- data/vendor/c_exception/vendor/unity/test/testdata/mocksample.c +51 -51
- data/vendor/c_exception/vendor/unity/test/testdata/sample.yml +8 -8
- data/vendor/c_exception/vendor/unity/test/testdata/testsample.c +68 -51
- data/vendor/{cmock/vendor/c_exception/vendor/unity/test → c_exception/vendor/unity/test/tests}/test_generate_test_runner.rb +102 -88
- data/vendor/{cmock/vendor/c_exception/vendor/unity/test → c_exception/vendor/unity/test/tests}/testparameterized.c +104 -101
- data/vendor/c_exception/vendor/unity/test/{testunity.c → tests/testunity.c} +3682 -3447
- data/vendor/cmock/docs/CMock_Summary.md +3 -0
- data/vendor/cmock/lib/cmock_config.rb +1 -0
- data/vendor/cmock/lib/cmock_file_writer.rb +7 -3
- data/vendor/cmock/lib/cmock_generator.rb +3 -2
- data/vendor/cmock/lib/cmock_header_parser.rb +12 -5
- data/vendor/cmock/release/version.info +1 -1
- data/vendor/cmock/test/system/test_compilation/parsing.h +3 -0
- data/vendor/cmock/test/unit/cmock_generator_main_test.rb +7 -0
- data/vendor/cmock/test/unit/cmock_header_parser_test.rb +57 -1
- data/vendor/cmock/vendor/c_exception/LICENSE.txt +30 -30
- data/vendor/cmock/vendor/c_exception/README.md +11 -1
- data/vendor/cmock/vendor/c_exception/docs/CExceptionSummary.odt +0 -0
- data/vendor/cmock/vendor/c_exception/docs/CExceptionSummary.pdf +0 -0
- data/vendor/cmock/vendor/c_exception/docs/readme.txt +261 -242
- data/vendor/cmock/vendor/c_exception/lib/CException.c +46 -46
- data/vendor/cmock/vendor/c_exception/lib/CException.h +110 -86
- data/vendor/cmock/vendor/c_exception/makefile +23 -23
- data/vendor/cmock/vendor/c_exception/test/CExceptionConfig.h +46 -46
- data/vendor/cmock/vendor/c_exception/test/TestException.c +391 -342
- data/vendor/cmock/vendor/c_exception/test/TestException_Runner.c +5 -12
- data/vendor/cmock/vendor/c_exception/vendor/unity/README.md +211 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/colour_prompt.rb +1 -1
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/colour_reporter.rb +38 -38
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/generate_config.yml +36 -36
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/generate_module.rb +202 -202
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/generate_test_runner.rb +391 -320
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/parseOutput.rb +2 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/stylize_as_junit.rb +260 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/type_sanitizer.rb +8 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/unity_test_summary.py +135 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/auto/unity_test_summary.rb +148 -139
- data/vendor/cmock/vendor/c_exception/vendor/unity/docs/Unity Summary.odt +0 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/docs/Unity Summary.pdf +0 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/docs/Unity Summary.txt +224 -216
- data/vendor/cmock/vendor/c_exception/vendor/unity/docs/license.txt +21 -31
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_1/makefile +40 -15
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_1/src/ProductionCode2.c +2 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_1/test/test_runners/TestProductionCode2_Runner.c +32 -25
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_1/test/test_runners/TestProductionCode_Runner.c +29 -22
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_2/makefile +40 -14
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_2/src/ProductionCode2.c +2 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_2/test/test_runners/all_tests.c +2 -2
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_3/rakefile.rb +0 -1
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_3/src/ProductionCode2.c +2 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/rakefile.rb +48 -37
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/rakefile_helper.rb +179 -179
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture.c +135 -94
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture.h +13 -17
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture_internals.h +12 -18
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/src/unity_fixture_malloc_overrides.h +30 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/test/Makefile +60 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/test/main/AllTests.c +4 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/test/{testunity_fixture.c → template_fixture_tests.c} +0 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/test/unity_fixture_Test.c +182 -27
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/test/unity_fixture_TestRunner.c +13 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/test/unity_output_Spy.c +8 -6
- data/vendor/cmock/vendor/c_exception/vendor/unity/extras/fixture/test/unity_output_Spy.h +2 -2
- data/vendor/cmock/vendor/c_exception/vendor/unity/release/build.info +1 -1
- data/vendor/cmock/vendor/c_exception/vendor/unity/release/version.info +1 -1
- data/vendor/cmock/vendor/c_exception/vendor/unity/src/unity.c +1333 -1145
- data/vendor/cmock/vendor/c_exception/vendor/unity/src/unity.h +290 -307
- data/vendor/cmock/vendor/c_exception/vendor/unity/src/unity_internals.h +758 -620
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_cmd.c +7 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_def.c +7 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_head1.c +55 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_head1.h +15 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_cmd.c +4 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_def.c +4 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_head1.c +75 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_head1.h +13 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_new1.c +6 -5
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_new2.c +4 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_param.c +4 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_run1.c +6 -5
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_run2.c +4 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_mock_yaml.c +7 -6
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_new1.c +9 -5
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_new2.c +7 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_param.c +7 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_run1.c +9 -5
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_run2.c +7 -3
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/expectdata/testsample_yaml.c +10 -6
- data/vendor/cmock/vendor/c_exception/vendor/unity/{rakefile.rb → test/rakefile} +60 -61
- data/vendor/cmock/vendor/c_exception/vendor/unity/{rakefile_helper.rb → test/rakefile_helper.rb} +255 -249
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/targets/clang_file.yml +83 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/{targets → test/targets}/clang_strict.yml +83 -83
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/targets/gcc_32.yml +49 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/targets/gcc_64.yml +50 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/{targets/gcc_32.yml → test/targets/gcc_auto_limits.yml} +46 -44
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/targets/gcc_auto_sizeof.yml +47 -0
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/targets/gcc_auto_stdint.yml +58 -0
- data/vendor/{c_exception/vendor/unity/targets/gcc_32.yml → cmock/vendor/c_exception/vendor/unity/test/targets/gcc_manual_math.yml} +46 -44
- data/vendor/{c_exception/vendor/unity → cmock/vendor/c_exception/vendor/unity/test}/targets/hitech_picc18.yml +101 -101
- data/vendor/{c_exception/vendor/unity → cmock/vendor/c_exception/vendor/unity/test}/targets/iar_arm_v4.yml +89 -89
- data/vendor/{c_exception/vendor/unity → cmock/vendor/c_exception/vendor/unity/test}/targets/iar_arm_v5.yml +79 -79
- data/vendor/cmock/vendor/c_exception/vendor/unity/{targets → test/targets}/iar_arm_v5_3.yml +79 -79
- data/vendor/{c_exception/vendor/unity → cmock/vendor/c_exception/vendor/unity/test}/targets/iar_armcortex_LM3S9B92_v5_4.yml +93 -93
- data/vendor/cmock/vendor/c_exception/vendor/unity/{targets → test/targets}/iar_cortexm3_v5.yml +83 -83
- data/vendor/{c_exception/vendor/unity → cmock/vendor/c_exception/vendor/unity/test}/targets/iar_msp430.yml +94 -94
- data/vendor/cmock/vendor/c_exception/vendor/unity/{targets → test/targets}/iar_sh2a_v6.yml +85 -85
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/testdata/mocksample.c +51 -51
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/testdata/sample.yml +8 -8
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/testdata/testsample.c +68 -51
- data/vendor/{c_exception/vendor/unity/test → cmock/vendor/c_exception/vendor/unity/test/tests}/test_generate_test_runner.rb +102 -88
- data/vendor/{c_exception/vendor/unity/test → cmock/vendor/c_exception/vendor/unity/test/tests}/testparameterized.c +104 -101
- data/vendor/cmock/vendor/c_exception/vendor/unity/test/{testunity.c → tests/testunity.c} +3682 -3447
- data/vendor/cmock/vendor/unity/auto/generate_test_runner.rb +30 -13
- data/vendor/cmock/vendor/unity/auto/stylize_as_junit.rb +260 -0
- data/vendor/cmock/vendor/unity/extras/fixture/src/unity_fixture.c +96 -93
- data/vendor/cmock/vendor/unity/extras/fixture/src/unity_fixture.h +1 -1
- data/vendor/cmock/vendor/unity/extras/fixture/src/unity_fixture_internals.h +12 -19
- data/vendor/cmock/vendor/unity/extras/fixture/src/unity_fixture_malloc_overrides.h +18 -17
- data/vendor/cmock/vendor/unity/extras/fixture/test/Makefile +66 -5
- data/vendor/cmock/vendor/unity/extras/fixture/test/main/AllTests.c +2 -1
- data/vendor/cmock/vendor/unity/extras/fixture/test/{testunity_fixture.c → template_fixture_tests.c} +0 -0
- data/vendor/cmock/vendor/unity/extras/fixture/test/unity_fixture_Test.c +187 -27
- data/vendor/cmock/vendor/unity/extras/fixture/test/unity_fixture_TestRunner.c +14 -0
- data/vendor/cmock/vendor/unity/extras/fixture/test/unity_output_Spy.c +6 -5
- data/vendor/cmock/vendor/unity/release/version.info +1 -1
- data/vendor/cmock/vendor/unity/src/unity.c +38 -27
- data/vendor/cmock/vendor/unity/src/unity.h +5 -0
- data/vendor/cmock/vendor/unity/src/unity_internals.h +22 -18
- data/vendor/cmock/vendor/unity/test/Makefile +52 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_cmd.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_def.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_head1.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_head1.h +7 -4
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_mock_head1.h +6 -4
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_new1.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_new2.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_param.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_run1.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_run2.c +4 -0
- data/vendor/cmock/vendor/unity/test/expectdata/testsample_yaml.c +4 -0
- data/vendor/cmock/vendor/unity/test/rakefile_helper.rb +1 -1
- data/vendor/cmock/vendor/unity/test/targets/clang_file.yml +0 -1
- data/vendor/cmock/vendor/unity/test/targets/clang_strict.yml +0 -1
- data/vendor/cmock/vendor/unity/test/targets/gcc_32.yml +0 -1
- data/vendor/cmock/vendor/unity/test/targets/gcc_64.yml +0 -1
- data/vendor/cmock/vendor/unity/test/targets/gcc_auto_limits.yml +0 -1
- data/vendor/cmock/vendor/unity/test/targets/gcc_auto_sizeof.yml +0 -1
- data/vendor/cmock/vendor/unity/test/targets/gcc_auto_stdint.yml +0 -1
- data/vendor/cmock/vendor/unity/test/targets/gcc_manual_math.yml +0 -1
- data/vendor/cmock/vendor/unity/test/testdata/testsample.c +19 -2
- data/vendor/cmock/vendor/unity/test/tests/testunity.c +55 -4
- data/vendor/unity/auto/generate_test_runner.rb +4 -2
- data/vendor/unity/auto/stylize_as_junit.rb +260 -0
- data/vendor/unity/extras/fixture/src/unity_fixture.c +24 -41
- data/vendor/unity/extras/fixture/src/unity_fixture.h +1 -1
- data/vendor/unity/extras/fixture/src/unity_fixture_internals.h +5 -7
- data/vendor/unity/extras/fixture/test/Makefile +53 -8
- data/vendor/unity/extras/fixture/test/{testunity_fixture.c → template_fixture_tests.c} +0 -0
- data/vendor/unity/extras/fixture/test/unity_fixture_Test.c +129 -32
- data/vendor/unity/extras/fixture/test/unity_fixture_TestRunner.c +6 -0
- data/vendor/unity/extras/fixture/test/unity_output_Spy.c +4 -4
- data/vendor/unity/release/version.info +1 -1
- data/vendor/unity/src/unity.c +32 -21
- data/vendor/unity/src/unity.h +5 -0
- data/vendor/unity/src/unity_internals.h +7 -3
- data/vendor/unity/test/Makefile +52 -0
- data/vendor/unity/test/expectdata/testsample_cmd.c +4 -0
- data/vendor/unity/test/expectdata/testsample_def.c +4 -0
- data/vendor/unity/test/expectdata/testsample_head1.c +4 -0
- data/vendor/unity/test/expectdata/testsample_head1.h +7 -4
- data/vendor/unity/test/expectdata/testsample_mock_head1.h +6 -4
- data/vendor/unity/test/expectdata/testsample_new1.c +4 -0
- data/vendor/unity/test/expectdata/testsample_new2.c +4 -0
- data/vendor/unity/test/expectdata/testsample_param.c +4 -0
- data/vendor/unity/test/expectdata/testsample_run1.c +4 -0
- data/vendor/unity/test/expectdata/testsample_run2.c +4 -0
- data/vendor/unity/test/expectdata/testsample_yaml.c +4 -0
- data/vendor/unity/test/testdata/testsample.c +19 -2
- data/vendor/unity/test/tests/testunity.c +35 -4
- metadata +75 -52
- data/ceedling-0.18.0.gem +0 -0
- data/docs/CeedlingLogo.png +0 -0
- data/vendor/c_exception/vendor/unity/Gemfile +0 -4
- data/vendor/c_exception/vendor/unity/Gemfile.lock +0 -12
- data/vendor/c_exception/vendor/unity/examples/example_3/makefile +0 -41
- data/vendor/c_exception/vendor/unity/examples/example_3/test/no_ruby/TestProductionCode2_Runner.c +0 -46
- data/vendor/c_exception/vendor/unity/examples/example_3/test/no_ruby/TestProductionCode_Runner.c +0 -50
- data/vendor/c_exception/vendor/unity/makefile +0 -37
- data/vendor/cmock/vendor/c_exception/vendor/unity/Gemfile +0 -4
- data/vendor/cmock/vendor/c_exception/vendor/unity/Gemfile.lock +0 -12
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_3/makefile +0 -41
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_3/test/no_ruby/TestProductionCode2_Runner.c +0 -46
- data/vendor/cmock/vendor/c_exception/vendor/unity/examples/example_3/test/no_ruby/TestProductionCode_Runner.c +0 -50
- data/vendor/cmock/vendor/c_exception/vendor/unity/makefile +0 -37
|
@@ -40,21 +40,13 @@ extern void test_CanHaveNestedTryBlocksInASingleFunction_ThrowInside(void);
|
|
|
40
40
|
extern void test_CanHaveNestedTryBlocksInASingleFunction_ThrowOutside(void);
|
|
41
41
|
extern void test_AThrowWithoutATryCatchWillUseDefaultHandlerIfSpecified(void);
|
|
42
42
|
extern void test_AThrowWithoutOutsideATryCatchWillUseDefaultHandlerEvenAfterTryCatch(void);
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
//=======Test Reset Option=====
|
|
46
|
-
void resetTest()
|
|
47
|
-
{
|
|
48
|
-
tearDown();
|
|
49
|
-
setUp();
|
|
50
|
-
}
|
|
51
|
-
|
|
43
|
+
extern void test_AbilityToExitTryWithoutThrowingAnError(void);
|
|
44
|
+
extern void test_AbilityToExitTryWillOnlyExitOneLevel(void);
|
|
52
45
|
|
|
53
46
|
//=======MAIN=====
|
|
54
47
|
int main(void)
|
|
55
48
|
{
|
|
56
|
-
|
|
57
|
-
UnityBegin();
|
|
49
|
+
UnityBegin("TestException.c");
|
|
58
50
|
RUN_TEST(test_BasicTryDoesNothingIfNoThrow, 16);
|
|
59
51
|
RUN_TEST(test_BasicThrowAndCatch, 37);
|
|
60
52
|
RUN_TEST(test_BasicThrowAndCatch_WithMiniSyntax, 56);
|
|
@@ -69,6 +61,7 @@ int main(void)
|
|
|
69
61
|
RUN_TEST(test_CanHaveNestedTryBlocksInASingleFunction_ThrowOutside, 281);
|
|
70
62
|
RUN_TEST(test_AThrowWithoutATryCatchWillUseDefaultHandlerIfSpecified, 308);
|
|
71
63
|
RUN_TEST(test_AThrowWithoutOutsideATryCatchWillUseDefaultHandlerEvenAfterTryCatch, 319);
|
|
72
|
-
|
|
64
|
+
RUN_TEST(test_AbilityToExitTryWithoutThrowingAnError, 344);
|
|
65
|
+
RUN_TEST(test_AbilityToExitTryWillOnlyExitOneLevel, 363);
|
|
73
66
|
return (UnityEnd());
|
|
74
67
|
}
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
Unity Test API
|
|
2
|
+
==============
|
|
3
|
+
|
|
4
|
+
[](https://travis-ci.org/ThrowTheSwitch/Unity)
|
|
5
|
+
__Copyright (c) 2007 - 2014 Unity Project by Mike Karlesky, Mark VanderVoord, and Greg Williams__
|
|
6
|
+
|
|
7
|
+
Running Tests
|
|
8
|
+
-------------
|
|
9
|
+
|
|
10
|
+
RUN_TEST(func, linenum)
|
|
11
|
+
|
|
12
|
+
Each Test is run within the macro `RUN_TEST`. This macro performs necessary setup before the test is called and handles cleanup and result tabulation afterwards.
|
|
13
|
+
|
|
14
|
+
Ignoring Tests
|
|
15
|
+
--------------
|
|
16
|
+
|
|
17
|
+
There are times when a test is incomplete or not valid for some reason. At these times, TEST_IGNORE can be called. Control will immediately be returned to the caller of the test, and no failures will be returned.
|
|
18
|
+
|
|
19
|
+
TEST_IGNORE()
|
|
20
|
+
|
|
21
|
+
Ignore this test and return immediately
|
|
22
|
+
|
|
23
|
+
TEST_IGNORE_MESSAGE (message)
|
|
24
|
+
|
|
25
|
+
Ignore this test and return immediately. Output a message stating why the test was ignored.
|
|
26
|
+
|
|
27
|
+
Aborting Tests
|
|
28
|
+
--------------
|
|
29
|
+
|
|
30
|
+
There are times when a test will contain an infinite loop on error conditions, or there may be reason to escape from the test early without executing the rest of the test. A pair of macros support this functionality in Unity. The first `TEST_PROTECT` sets up the feature, and handles emergency abort cases. `TEST_ABORT` can then be used at any time within the tests to return to the last `TEST_PROTECT` call.
|
|
31
|
+
|
|
32
|
+
TEST_PROTECT()
|
|
33
|
+
|
|
34
|
+
Setup and Catch macro
|
|
35
|
+
|
|
36
|
+
TEST_ABORT()
|
|
37
|
+
|
|
38
|
+
Abort Test macro
|
|
39
|
+
|
|
40
|
+
Example:
|
|
41
|
+
|
|
42
|
+
main()
|
|
43
|
+
{
|
|
44
|
+
if (TEST_PROTECT() == 0)
|
|
45
|
+
{
|
|
46
|
+
MyTest();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
If MyTest calls `TEST_ABORT`, program control will immediately return to `TEST_PROTECT` with a non-zero return value.
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
Unity Assertion Summary
|
|
54
|
+
=======================
|
|
55
|
+
|
|
56
|
+
Basic Validity Tests
|
|
57
|
+
--------------------
|
|
58
|
+
|
|
59
|
+
TEST_ASSERT_TRUE(condition)
|
|
60
|
+
|
|
61
|
+
Evaluates whatever code is in condition and fails if it evaluates to false
|
|
62
|
+
|
|
63
|
+
TEST_ASSERT_FALSE(condition)
|
|
64
|
+
|
|
65
|
+
Evaluates whatever code is in condition and fails if it evaluates to true
|
|
66
|
+
|
|
67
|
+
TEST_ASSERT(condition)
|
|
68
|
+
|
|
69
|
+
Another way of calling `TEST_ASSERT_TRUE`
|
|
70
|
+
|
|
71
|
+
TEST_ASSERT_UNLESS(condition)
|
|
72
|
+
|
|
73
|
+
Another way of calling `TEST_ASSERT_FALSE`
|
|
74
|
+
|
|
75
|
+
TEST_FAIL()
|
|
76
|
+
TEST_FAIL_MESSAGE(message)
|
|
77
|
+
|
|
78
|
+
This test is automatically marked as a failure. The message is output stating why.
|
|
79
|
+
|
|
80
|
+
Numerical Assertions: Integers
|
|
81
|
+
------------------------------
|
|
82
|
+
|
|
83
|
+
TEST_ASSERT_EQUAL_INT(expected, actual)
|
|
84
|
+
TEST_ASSERT_EQUAL_INT8(expected, actual)
|
|
85
|
+
TEST_ASSERT_EQUAL_INT16(expected, actual)
|
|
86
|
+
TEST_ASSERT_EQUAL_INT32(expected, actual)
|
|
87
|
+
TEST_ASSERT_EQUAL_INT64(expected, actual)
|
|
88
|
+
|
|
89
|
+
Compare two integers for equality and display errors as signed integers. A cast will be performed
|
|
90
|
+
to your natural integer size so often this can just be used. When you need to specify the exact size,
|
|
91
|
+
like when comparing arrays, you can use a specific version:
|
|
92
|
+
|
|
93
|
+
TEST_ASSERT_EQUAL_UINT(expected, actual)
|
|
94
|
+
TEST_ASSERT_EQUAL_UINT8(expected, actual)
|
|
95
|
+
TEST_ASSERT_EQUAL_UINT16(expected, actual)
|
|
96
|
+
TEST_ASSERT_EQUAL_UINT32(expected, actual)
|
|
97
|
+
TEST_ASSERT_EQUAL_UINT64(expected, actual)
|
|
98
|
+
|
|
99
|
+
Compare two integers for equality and display errors as unsigned integers. Like INT, there are
|
|
100
|
+
variants for different sizes also.
|
|
101
|
+
|
|
102
|
+
TEST_ASSERT_EQUAL_HEX(expected, actual)
|
|
103
|
+
TEST_ASSERT_EQUAL_HEX8(expected, actual)
|
|
104
|
+
TEST_ASSERT_EQUAL_HEX16(expected, actual)
|
|
105
|
+
TEST_ASSERT_EQUAL_HEX32(expected, actual)
|
|
106
|
+
TEST_ASSERT_EQUAL_HEX64(expected, actual)
|
|
107
|
+
|
|
108
|
+
Compares two integers for equality and display errors as hexadecimal. Like the other integer comparisons,
|
|
109
|
+
you can specify the size... here the size will also effect how many nibbles are shown (for example, `HEX16`
|
|
110
|
+
will show 4 nibbles).
|
|
111
|
+
|
|
112
|
+
_ARRAY
|
|
113
|
+
|
|
114
|
+
You can append `_ARRAY` to any of these macros to make an array comparison of that type. Here you will
|
|
115
|
+
need to care a bit more about the actual size of the value being checked. You will also specify an
|
|
116
|
+
additional argument which is the number of elements to compare. For example:
|
|
117
|
+
|
|
118
|
+
TEST_ASSERT_EQUAL_HEX8_ARRAY(expected, actual, elements)
|
|
119
|
+
|
|
120
|
+
TEST_ASSERT_EQUAL(expected, actual)
|
|
121
|
+
|
|
122
|
+
Another way of calling TEST_ASSERT_EQUAL_INT
|
|
123
|
+
|
|
124
|
+
TEST_ASSERT_INT_WITHIN(delta, expected, actual)
|
|
125
|
+
|
|
126
|
+
Asserts that the actual value is within plus or minus delta of the expected value. This also comes in
|
|
127
|
+
size specific variants.
|
|
128
|
+
|
|
129
|
+
|
|
130
|
+
Numerical Assertions: Bitwise
|
|
131
|
+
-----------------------------
|
|
132
|
+
|
|
133
|
+
TEST_ASSERT_BITS(mask, expected, actual)
|
|
134
|
+
|
|
135
|
+
Use an integer mask to specify which bits should be compared between two other integers. High bits in the mask are compared, low bits ignored.
|
|
136
|
+
|
|
137
|
+
TEST_ASSERT_BITS_HIGH(mask, actual)
|
|
138
|
+
|
|
139
|
+
Use an integer mask to specify which bits should be inspected to determine if they are all set high. High bits in the mask are compared, low bits ignored.
|
|
140
|
+
|
|
141
|
+
TEST_ASSERT_BITS_LOW(mask, actual)
|
|
142
|
+
|
|
143
|
+
Use an integer mask to specify which bits should be inspected to determine if they are all set low. High bits in the mask are compared, low bits ignored.
|
|
144
|
+
|
|
145
|
+
TEST_ASSERT_BIT_HIGH(bit, actual)
|
|
146
|
+
|
|
147
|
+
Test a single bit and verify that it is high. The bit is specified 0-31 for a 32-bit integer.
|
|
148
|
+
|
|
149
|
+
TEST_ASSERT_BIT_LOW(bit, actual)
|
|
150
|
+
|
|
151
|
+
Test a single bit and verify that it is low. The bit is specified 0-31 for a 32-bit integer.
|
|
152
|
+
|
|
153
|
+
Numerical Assertions: Floats
|
|
154
|
+
----------------------------
|
|
155
|
+
|
|
156
|
+
TEST_ASSERT_FLOAT_WITHIN(delta, expected, actual)
|
|
157
|
+
|
|
158
|
+
Asserts that the actual value is within plus or minus delta of the expected value.
|
|
159
|
+
|
|
160
|
+
TEST_ASSERT_EQUAL_FLOAT(expected, actual)
|
|
161
|
+
TEST_ASSERT_EQUAL_DOUBLE(expected, actual)
|
|
162
|
+
|
|
163
|
+
Asserts that two floating point values are "equal" within a small % delta of the expected value.
|
|
164
|
+
|
|
165
|
+
String Assertions
|
|
166
|
+
-----------------
|
|
167
|
+
|
|
168
|
+
TEST_ASSERT_EQUAL_STRING(expected, actual)
|
|
169
|
+
|
|
170
|
+
Compare two null-terminate strings. Fail if any character is different or if the lengths are different.
|
|
171
|
+
|
|
172
|
+
TEST_ASSERT_EQUAL_STRING_LEN(expected, actual, len)
|
|
173
|
+
|
|
174
|
+
Compare two strings. Fail if any character is different, stop comparing after len characters.
|
|
175
|
+
|
|
176
|
+
TEST_ASSERT_EQUAL_STRING_MESSAGE(expected, actual, message)
|
|
177
|
+
|
|
178
|
+
Compare two null-terminate strings. Fail if any character is different or if the lengths are different. Output a custom message on failure.
|
|
179
|
+
|
|
180
|
+
TEST_ASSERT_EQUAL_STRING_LEN_MESSAGE(expected, actual, len, message)
|
|
181
|
+
|
|
182
|
+
Compare two strings. Fail if any character is different, stop comparing after len characters. Output a custom message on failure.
|
|
183
|
+
|
|
184
|
+
Pointer Assertions
|
|
185
|
+
------------------
|
|
186
|
+
|
|
187
|
+
Most pointer operations can be performed by simply using the integer comparisons above. However, a couple of special cases are added for clarity.
|
|
188
|
+
|
|
189
|
+
TEST_ASSERT_NULL(pointer)
|
|
190
|
+
|
|
191
|
+
Fails if the pointer is not equal to NULL
|
|
192
|
+
|
|
193
|
+
TEST_ASSERT_NOT_NULL(pointer)
|
|
194
|
+
|
|
195
|
+
Fails if the pointer is equal to NULL
|
|
196
|
+
|
|
197
|
+
Memory Assertions
|
|
198
|
+
-----------------
|
|
199
|
+
|
|
200
|
+
TEST_ASSERT_EQUAL_MEMORY(expected, actual, len)
|
|
201
|
+
|
|
202
|
+
Compare two blocks of memory. This is a good generic assertion for types that can't be coerced into acting like
|
|
203
|
+
standard types... but since it's a memory compare, you have to be careful that your data types are packed.
|
|
204
|
+
|
|
205
|
+
_MESSAGE
|
|
206
|
+
--------
|
|
207
|
+
|
|
208
|
+
you can append _MESSAGE to any of the macros to make them take an additional argument. This argument
|
|
209
|
+
is a string that will be printed at the end of the failure strings. This is useful for specifying more
|
|
210
|
+
information about the problem.
|
|
211
|
+
|
|
@@ -24,7 +24,7 @@ class ColourCommandLine
|
|
|
24
24
|
if RUBY_PLATFORM =~/(win|w)32$/
|
|
25
25
|
get_std_handle = Win32API.new("kernel32", "GetStdHandle", ['L'], 'L')
|
|
26
26
|
@set_console_txt_attrb =
|
|
27
|
-
|
|
27
|
+
Win32API.new("kernel32","SetConsoleTextAttribute",['L','N'], 'I')
|
|
28
28
|
@hout = get_std_handle.call(-11)
|
|
29
29
|
end
|
|
30
30
|
end
|
|
@@ -1,39 +1,39 @@
|
|
|
1
|
-
# ==========================================
|
|
2
|
-
# Unity Project - A Test Framework for C
|
|
3
|
-
# Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
|
4
|
-
# [Released under MIT License. Please refer to license.txt for details]
|
|
5
|
-
# ==========================================
|
|
6
|
-
|
|
7
|
-
require "#{File.expand_path(File.dirname(__FILE__))}/colour_prompt"
|
|
8
|
-
|
|
9
|
-
$colour_output = true
|
|
10
|
-
|
|
11
|
-
def report(message)
|
|
12
|
-
if not $colour_output
|
|
13
|
-
$stdout.puts(message)
|
|
14
|
-
else
|
|
15
|
-
message = message.join('\n') if (message.class == Array)
|
|
16
|
-
message.each_line do |line|
|
|
17
|
-
line.chomp!
|
|
18
|
-
colour = case(line)
|
|
19
|
-
when /(?:total\s+)?tests:?\s+(\d+)\s+(?:total\s+)?failures:?\s+\d+\s+Ignored:?/i
|
|
20
|
-
($1.to_i == 0) ? :green : :red
|
|
21
|
-
when /PASS/
|
|
22
|
-
:green
|
|
23
|
-
when /^OK$/
|
|
24
|
-
:green
|
|
25
|
-
when /(?:FAIL|ERROR)/
|
|
26
|
-
:red
|
|
27
|
-
when /IGNORE/
|
|
28
|
-
:yellow
|
|
29
|
-
when /^(?:Creating|Compiling|Linking)/
|
|
30
|
-
:white
|
|
31
|
-
else
|
|
32
|
-
:silver
|
|
33
|
-
end
|
|
34
|
-
colour_puts(colour, line)
|
|
35
|
-
end
|
|
36
|
-
end
|
|
37
|
-
$stdout.flush
|
|
38
|
-
$stderr.flush
|
|
1
|
+
# ==========================================
|
|
2
|
+
# Unity Project - A Test Framework for C
|
|
3
|
+
# Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
|
4
|
+
# [Released under MIT License. Please refer to license.txt for details]
|
|
5
|
+
# ==========================================
|
|
6
|
+
|
|
7
|
+
require "#{File.expand_path(File.dirname(__FILE__))}/colour_prompt"
|
|
8
|
+
|
|
9
|
+
$colour_output = true
|
|
10
|
+
|
|
11
|
+
def report(message)
|
|
12
|
+
if not $colour_output
|
|
13
|
+
$stdout.puts(message)
|
|
14
|
+
else
|
|
15
|
+
message = message.join('\n') if (message.class == Array)
|
|
16
|
+
message.each_line do |line|
|
|
17
|
+
line.chomp!
|
|
18
|
+
colour = case(line)
|
|
19
|
+
when /(?:total\s+)?tests:?\s+(\d+)\s+(?:total\s+)?failures:?\s+\d+\s+Ignored:?/i
|
|
20
|
+
($1.to_i == 0) ? :green : :red
|
|
21
|
+
when /PASS/
|
|
22
|
+
:green
|
|
23
|
+
when /^OK$/
|
|
24
|
+
:green
|
|
25
|
+
when /(?:FAIL|ERROR)/
|
|
26
|
+
:red
|
|
27
|
+
when /IGNORE/
|
|
28
|
+
:yellow
|
|
29
|
+
when /^(?:Creating|Compiling|Linking)/
|
|
30
|
+
:white
|
|
31
|
+
else
|
|
32
|
+
:silver
|
|
33
|
+
end
|
|
34
|
+
colour_puts(colour, line)
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
$stdout.flush
|
|
38
|
+
$stderr.flush
|
|
39
39
|
end
|
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
#this is a sample configuration file for generate_module
|
|
2
|
-
#you would use it by calling generate_module with the -ygenerate_config.yml option
|
|
3
|
-
#files like this are useful for customizing generate_module to your environment
|
|
4
|
-
:generate_module:
|
|
5
|
-
:defaults:
|
|
6
|
-
#these defaults are used in place of any missing options at the command line
|
|
7
|
-
:path_src: ../src/
|
|
8
|
-
:path_inc: ../src/
|
|
9
|
-
:path_tst: ../test/
|
|
10
|
-
:update_svn: true
|
|
11
|
-
:includes:
|
|
12
|
-
#use [] for no additional includes, otherwise list the includes on separate lines
|
|
13
|
-
:src:
|
|
14
|
-
- Defs.h
|
|
15
|
-
- Board.h
|
|
16
|
-
:inc: []
|
|
17
|
-
:tst:
|
|
18
|
-
- Defs.h
|
|
19
|
-
- Board.h
|
|
20
|
-
- Exception.h
|
|
21
|
-
:boilerplates:
|
|
22
|
-
#these are inserted at the top of generated files.
|
|
23
|
-
#just comment out or remove if not desired.
|
|
24
|
-
#use %1$s where you would like the file name to appear (path/extension not included)
|
|
25
|
-
:src: |
|
|
26
|
-
//-------------------------------------------
|
|
27
|
-
// %1$s.c
|
|
28
|
-
//-------------------------------------------
|
|
29
|
-
:inc: |
|
|
30
|
-
//-------------------------------------------
|
|
31
|
-
// %1$s.h
|
|
32
|
-
//-------------------------------------------
|
|
33
|
-
:tst: |
|
|
34
|
-
//-------------------------------------------
|
|
35
|
-
// Test%1$s.c : Units tests for %1$s.c
|
|
36
|
-
//-------------------------------------------
|
|
1
|
+
#this is a sample configuration file for generate_module
|
|
2
|
+
#you would use it by calling generate_module with the -ygenerate_config.yml option
|
|
3
|
+
#files like this are useful for customizing generate_module to your environment
|
|
4
|
+
:generate_module:
|
|
5
|
+
:defaults:
|
|
6
|
+
#these defaults are used in place of any missing options at the command line
|
|
7
|
+
:path_src: ../src/
|
|
8
|
+
:path_inc: ../src/
|
|
9
|
+
:path_tst: ../test/
|
|
10
|
+
:update_svn: true
|
|
11
|
+
:includes:
|
|
12
|
+
#use [] for no additional includes, otherwise list the includes on separate lines
|
|
13
|
+
:src:
|
|
14
|
+
- Defs.h
|
|
15
|
+
- Board.h
|
|
16
|
+
:inc: []
|
|
17
|
+
:tst:
|
|
18
|
+
- Defs.h
|
|
19
|
+
- Board.h
|
|
20
|
+
- Exception.h
|
|
21
|
+
:boilerplates:
|
|
22
|
+
#these are inserted at the top of generated files.
|
|
23
|
+
#just comment out or remove if not desired.
|
|
24
|
+
#use %1$s where you would like the file name to appear (path/extension not included)
|
|
25
|
+
:src: |
|
|
26
|
+
//-------------------------------------------
|
|
27
|
+
// %1$s.c
|
|
28
|
+
//-------------------------------------------
|
|
29
|
+
:inc: |
|
|
30
|
+
//-------------------------------------------
|
|
31
|
+
// %1$s.h
|
|
32
|
+
//-------------------------------------------
|
|
33
|
+
:tst: |
|
|
34
|
+
//-------------------------------------------
|
|
35
|
+
// Test%1$s.c : Units tests for %1$s.c
|
|
36
|
+
//-------------------------------------------
|
|
@@ -1,202 +1,202 @@
|
|
|
1
|
-
# ==========================================
|
|
2
|
-
# Unity Project - A Test Framework for C
|
|
3
|
-
# Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
|
4
|
-
# [Released under MIT License. Please refer to license.txt for details]
|
|
5
|
-
# ==========================================
|
|
6
|
-
|
|
7
|
-
# This script creates all the files with start code necessary for a new module.
|
|
8
|
-
# A simple module only requires a source file, header file, and test file.
|
|
9
|
-
# Triad modules require a source, header, and test file for each triad type (like model, conductor, and hardware).
|
|
10
|
-
|
|
11
|
-
require 'rubygems'
|
|
12
|
-
require 'fileutils'
|
|
13
|
-
|
|
14
|
-
HERE = File.expand_path(File.dirname(__FILE__)) + '/'
|
|
15
|
-
|
|
16
|
-
#help text when requested
|
|
17
|
-
HELP_TEXT = [ "\nGENERATE MODULE\n-------- ------",
|
|
18
|
-
"\nUsage: ruby generate_module [options] module_name",
|
|
19
|
-
" -i\"include\" sets the path to output headers to 'include' (DEFAULT ../src)",
|
|
20
|
-
" -s\"../src\" sets the path to output source to '../src' (DEFAULT ../src)",
|
|
21
|
-
" -t\"C:/test\" sets the path to output source to 'C:/test' (DEFAULT ../test)",
|
|
22
|
-
" -p\"MCH\" sets the output pattern to MCH.",
|
|
23
|
-
" dh - driver hardware.",
|
|
24
|
-
" dih - driver interrupt hardware.",
|
|
25
|
-
" mch - model conductor hardware.",
|
|
26
|
-
" mvp - model view presenter.",
|
|
27
|
-
" src - just a single source module. (DEFAULT)",
|
|
28
|
-
" -d destroy module instead of creating it.",
|
|
29
|
-
" -u update subversion too (requires subversion command line)",
|
|
30
|
-
" -y\"my.yml\" selects a different yaml config file for module generation",
|
|
31
|
-
"" ].join("\n")
|
|
32
|
-
|
|
33
|
-
#Built in patterns
|
|
34
|
-
PATTERNS = { 'src' => {'' => { :inc => [] } },
|
|
35
|
-
'dh' => {'Driver' => { :inc => ['%1$sHardware.h'] },
|
|
36
|
-
'Hardware' => { :inc => [] }
|
|
37
|
-
},
|
|
38
|
-
'dih' => {'Driver' => { :inc => ['%1$sHardware.h', '%1$sInterrupt.h'] },
|
|
39
|
-
'Interrupt'=> { :inc => ['%1$sHardware.h'] },
|
|
40
|
-
'Hardware' => { :inc => [] }
|
|
41
|
-
},
|
|
42
|
-
'mch' => {'Model' => { :inc => [] },
|
|
43
|
-
'Conductor'=> { :inc => ['%1$sModel.h', '%1$sHardware.h'] },
|
|
44
|
-
'Hardware' => { :inc => [] }
|
|
45
|
-
},
|
|
46
|
-
'mvp' => {'Model' => { :inc => [] },
|
|
47
|
-
'Presenter'=> { :inc => ['%1$sModel.h', '%1$sView.h'] },
|
|
48
|
-
'View' => { :inc => [] }
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
#TEMPLATE_TST
|
|
53
|
-
TEMPLATE_TST = %q[#include "unity.h"
|
|
54
|
-
%2$s#include "%1$s.h"
|
|
55
|
-
|
|
56
|
-
void setUp(void)
|
|
57
|
-
{
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
void tearDown(void)
|
|
61
|
-
{
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
void test_%1$s_NeedToImplement(void)
|
|
65
|
-
{
|
|
66
|
-
TEST_IGNORE();
|
|
67
|
-
}
|
|
68
|
-
]
|
|
69
|
-
|
|
70
|
-
#TEMPLATE_SRC
|
|
71
|
-
TEMPLATE_SRC = %q[%2$s#include "%1$s.h"
|
|
72
|
-
]
|
|
73
|
-
|
|
74
|
-
#TEMPLATE_INC
|
|
75
|
-
TEMPLATE_INC = %q[#ifndef _%3$s_H
|
|
76
|
-
#define _%3$s_H%2$s
|
|
77
|
-
|
|
78
|
-
#endif // _%3$s_H
|
|
79
|
-
]
|
|
80
|
-
|
|
81
|
-
# Parse the command line parameters.
|
|
82
|
-
ARGV.each do |arg|
|
|
83
|
-
case(arg)
|
|
84
|
-
when /^-d/ then @destroy = true
|
|
85
|
-
when /^-u/ then @update_svn = true
|
|
86
|
-
when /^-p(\w+)/ then @pattern = $1
|
|
87
|
-
when /^-s(.+)/ then @path_src = $1
|
|
88
|
-
when /^-i(.+)/ then @path_inc = $1
|
|
89
|
-
when /^-t(.+)/ then @path_tst = $1
|
|
90
|
-
when /^-y(.+)/ then @yaml_config = $1
|
|
91
|
-
when /^(\w+)/
|
|
92
|
-
raise "ERROR: You can't have more than one Module name specified!" unless @module_name.nil?
|
|
93
|
-
@module_name = arg
|
|
94
|
-
when /^-(h|-help)/
|
|
95
|
-
puts HELP_TEXT
|
|
96
|
-
exit
|
|
97
|
-
else
|
|
98
|
-
raise "ERROR: Unknown option specified '#{arg}'"
|
|
99
|
-
end
|
|
100
|
-
end
|
|
101
|
-
raise "ERROR: You must have a Module name specified! (use option -h for help)" if @module_name.nil?
|
|
102
|
-
|
|
103
|
-
#load yaml file if one was requested
|
|
104
|
-
if @yaml_config
|
|
105
|
-
require 'yaml'
|
|
106
|
-
cfg = YAML.load_file(HERE + @yaml_config)[:generate_module]
|
|
107
|
-
@path_src = cfg[:defaults][:path_src] if @path_src.nil?
|
|
108
|
-
@path_inc = cfg[:defaults][:path_inc] if @path_inc.nil?
|
|
109
|
-
@path_tst = cfg[:defaults][:path_tst] if @path_tst.nil?
|
|
110
|
-
@update_svn = cfg[:defaults][:update_svn] if @update_svn.nil?
|
|
111
|
-
@extra_inc = cfg[:includes]
|
|
112
|
-
@boilerplates = cfg[:boilerplates]
|
|
113
|
-
else
|
|
114
|
-
@boilerplates = {}
|
|
115
|
-
end
|
|
116
|
-
|
|
117
|
-
# Create default file paths if none were provided
|
|
118
|
-
@path_src = HERE + "../src/" if @path_src.nil?
|
|
119
|
-
@path_inc = @path_src if @path_inc.nil?
|
|
120
|
-
@path_tst = HERE + "../test/" if @path_tst.nil?
|
|
121
|
-
@path_src += '/' unless (@path_src[-1] == 47)
|
|
122
|
-
@path_inc += '/' unless (@path_inc[-1] == 47)
|
|
123
|
-
@path_tst += '/' unless (@path_tst[-1] == 47)
|
|
124
|
-
@pattern = 'src' if @pattern.nil?
|
|
125
|
-
@includes = { :src => [], :inc => [], :tst => [] }
|
|
126
|
-
@includes.merge!(@extra_inc) unless @extra_inc.nil?
|
|
127
|
-
|
|
128
|
-
#create triad definition
|
|
129
|
-
TRIAD = [ { :ext => '.c', :path => @path_src, :template => TEMPLATE_SRC, :inc => :src, :boilerplate => @boilerplates[:src] },
|
|
130
|
-
{ :ext => '.h', :path => @path_inc, :template => TEMPLATE_INC, :inc => :inc, :boilerplate => @boilerplates[:inc] },
|
|
131
|
-
{ :ext => '.c', :path => @path_tst+'Test', :template => TEMPLATE_TST, :inc => :tst, :boilerplate => @boilerplates[:tst] },
|
|
132
|
-
]
|
|
133
|
-
|
|
134
|
-
#prepare the pattern for use
|
|
135
|
-
@patterns = PATTERNS[@pattern.downcase]
|
|
136
|
-
raise "ERROR: The design pattern specified isn't one that I recognize!" if @patterns.nil?
|
|
137
|
-
|
|
138
|
-
# Assemble the path/names of the files we need to work with.
|
|
139
|
-
files = []
|
|
140
|
-
TRIAD.each do |triad|
|
|
141
|
-
@patterns.each_pair do |pattern_file, pattern_traits|
|
|
142
|
-
files << {
|
|
143
|
-
:path => "#{triad[:path]}#{@module_name}#{pattern_file}#{triad[:ext]}",
|
|
144
|
-
:name => "#{@module_name}#{pattern_file}",
|
|
145
|
-
:template => triad[:template],
|
|
146
|
-
:boilerplate => triad[:boilerplate],
|
|
147
|
-
:includes => case(triad[:inc])
|
|
148
|
-
when :src then @includes[:src] | pattern_traits[:inc].map{|f| f % [@module_name]}
|
|
149
|
-
when :inc then @includes[:inc]
|
|
150
|
-
when :tst then @includes[:tst] | pattern_traits[:inc].map{|f| "Mock#{f}"% [@module_name]}
|
|
151
|
-
end
|
|
152
|
-
}
|
|
153
|
-
end
|
|
154
|
-
end
|
|
155
|
-
|
|
156
|
-
# destroy files if that was what was requested
|
|
157
|
-
if @destroy
|
|
158
|
-
files.each do |filespec|
|
|
159
|
-
file = filespec[:path]
|
|
160
|
-
if File.exist?(file)
|
|
161
|
-
if @update_svn
|
|
162
|
-
`svn delete \"#{file}\" --force`
|
|
163
|
-
puts "File #{file} deleted and removed from source control"
|
|
164
|
-
else
|
|
165
|
-
FileUtils.remove(file)
|
|
166
|
-
puts "File #{file} deleted"
|
|
167
|
-
end
|
|
168
|
-
else
|
|
169
|
-
puts "File #{file} does not exist so cannot be removed."
|
|
170
|
-
end
|
|
171
|
-
end
|
|
172
|
-
puts "Destroy Complete"
|
|
173
|
-
exit
|
|
174
|
-
end
|
|
175
|
-
|
|
176
|
-
#Abort if any module already exists
|
|
177
|
-
files.each do |file|
|
|
178
|
-
raise "ERROR: File #{file[:name]} already exists. Exiting." if File.exist?(file[:path])
|
|
179
|
-
end
|
|
180
|
-
|
|
181
|
-
# Create Source Modules
|
|
182
|
-
files.each_with_index do |file, i|
|
|
183
|
-
File.open(file[:path], 'w') do |f|
|
|
184
|
-
f.write(file[:boilerplate] % [file[:name]]) unless file[:boilerplate].nil?
|
|
185
|
-
f.write(file[:template] % [ file[:name],
|
|
186
|
-
file[:includes].map{|f| "#include \"#{f}\"\n"}.join,
|
|
187
|
-
file[:name].upcase ]
|
|
188
|
-
)
|
|
189
|
-
end
|
|
190
|
-
if (@update_svn)
|
|
191
|
-
`svn add \"#{file[:path]}\"`
|
|
192
|
-
if $?.exitstatus == 0
|
|
193
|
-
puts "File #{file[:path]} created and added to source control"
|
|
194
|
-
else
|
|
195
|
-
puts "File #{file[:path]} created but FAILED adding to source control!"
|
|
196
|
-
end
|
|
197
|
-
else
|
|
198
|
-
puts "File #{file[:path]} created"
|
|
199
|
-
end
|
|
200
|
-
end
|
|
201
|
-
|
|
202
|
-
puts 'Generate Complete'
|
|
1
|
+
# ==========================================
|
|
2
|
+
# Unity Project - A Test Framework for C
|
|
3
|
+
# Copyright (c) 2007 Mike Karlesky, Mark VanderVoord, Greg Williams
|
|
4
|
+
# [Released under MIT License. Please refer to license.txt for details]
|
|
5
|
+
# ==========================================
|
|
6
|
+
|
|
7
|
+
# This script creates all the files with start code necessary for a new module.
|
|
8
|
+
# A simple module only requires a source file, header file, and test file.
|
|
9
|
+
# Triad modules require a source, header, and test file for each triad type (like model, conductor, and hardware).
|
|
10
|
+
|
|
11
|
+
require 'rubygems'
|
|
12
|
+
require 'fileutils'
|
|
13
|
+
|
|
14
|
+
HERE = File.expand_path(File.dirname(__FILE__)) + '/'
|
|
15
|
+
|
|
16
|
+
#help text when requested
|
|
17
|
+
HELP_TEXT = [ "\nGENERATE MODULE\n-------- ------",
|
|
18
|
+
"\nUsage: ruby generate_module [options] module_name",
|
|
19
|
+
" -i\"include\" sets the path to output headers to 'include' (DEFAULT ../src)",
|
|
20
|
+
" -s\"../src\" sets the path to output source to '../src' (DEFAULT ../src)",
|
|
21
|
+
" -t\"C:/test\" sets the path to output source to 'C:/test' (DEFAULT ../test)",
|
|
22
|
+
" -p\"MCH\" sets the output pattern to MCH.",
|
|
23
|
+
" dh - driver hardware.",
|
|
24
|
+
" dih - driver interrupt hardware.",
|
|
25
|
+
" mch - model conductor hardware.",
|
|
26
|
+
" mvp - model view presenter.",
|
|
27
|
+
" src - just a single source module. (DEFAULT)",
|
|
28
|
+
" -d destroy module instead of creating it.",
|
|
29
|
+
" -u update subversion too (requires subversion command line)",
|
|
30
|
+
" -y\"my.yml\" selects a different yaml config file for module generation",
|
|
31
|
+
"" ].join("\n")
|
|
32
|
+
|
|
33
|
+
#Built in patterns
|
|
34
|
+
PATTERNS = { 'src' => {'' => { :inc => [] } },
|
|
35
|
+
'dh' => {'Driver' => { :inc => ['%1$sHardware.h'] },
|
|
36
|
+
'Hardware' => { :inc => [] }
|
|
37
|
+
},
|
|
38
|
+
'dih' => {'Driver' => { :inc => ['%1$sHardware.h', '%1$sInterrupt.h'] },
|
|
39
|
+
'Interrupt'=> { :inc => ['%1$sHardware.h'] },
|
|
40
|
+
'Hardware' => { :inc => [] }
|
|
41
|
+
},
|
|
42
|
+
'mch' => {'Model' => { :inc => [] },
|
|
43
|
+
'Conductor'=> { :inc => ['%1$sModel.h', '%1$sHardware.h'] },
|
|
44
|
+
'Hardware' => { :inc => [] }
|
|
45
|
+
},
|
|
46
|
+
'mvp' => {'Model' => { :inc => [] },
|
|
47
|
+
'Presenter'=> { :inc => ['%1$sModel.h', '%1$sView.h'] },
|
|
48
|
+
'View' => { :inc => [] }
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
#TEMPLATE_TST
|
|
53
|
+
TEMPLATE_TST = %q[#include "unity.h"
|
|
54
|
+
%2$s#include "%1$s.h"
|
|
55
|
+
|
|
56
|
+
void setUp(void)
|
|
57
|
+
{
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
void tearDown(void)
|
|
61
|
+
{
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
void test_%1$s_NeedToImplement(void)
|
|
65
|
+
{
|
|
66
|
+
TEST_IGNORE();
|
|
67
|
+
}
|
|
68
|
+
]
|
|
69
|
+
|
|
70
|
+
#TEMPLATE_SRC
|
|
71
|
+
TEMPLATE_SRC = %q[%2$s#include "%1$s.h"
|
|
72
|
+
]
|
|
73
|
+
|
|
74
|
+
#TEMPLATE_INC
|
|
75
|
+
TEMPLATE_INC = %q[#ifndef _%3$s_H
|
|
76
|
+
#define _%3$s_H%2$s
|
|
77
|
+
|
|
78
|
+
#endif // _%3$s_H
|
|
79
|
+
]
|
|
80
|
+
|
|
81
|
+
# Parse the command line parameters.
|
|
82
|
+
ARGV.each do |arg|
|
|
83
|
+
case(arg)
|
|
84
|
+
when /^-d/ then @destroy = true
|
|
85
|
+
when /^-u/ then @update_svn = true
|
|
86
|
+
when /^-p(\w+)/ then @pattern = $1
|
|
87
|
+
when /^-s(.+)/ then @path_src = $1
|
|
88
|
+
when /^-i(.+)/ then @path_inc = $1
|
|
89
|
+
when /^-t(.+)/ then @path_tst = $1
|
|
90
|
+
when /^-y(.+)/ then @yaml_config = $1
|
|
91
|
+
when /^(\w+)/
|
|
92
|
+
raise "ERROR: You can't have more than one Module name specified!" unless @module_name.nil?
|
|
93
|
+
@module_name = arg
|
|
94
|
+
when /^-(h|-help)/
|
|
95
|
+
puts HELP_TEXT
|
|
96
|
+
exit
|
|
97
|
+
else
|
|
98
|
+
raise "ERROR: Unknown option specified '#{arg}'"
|
|
99
|
+
end
|
|
100
|
+
end
|
|
101
|
+
raise "ERROR: You must have a Module name specified! (use option -h for help)" if @module_name.nil?
|
|
102
|
+
|
|
103
|
+
#load yaml file if one was requested
|
|
104
|
+
if @yaml_config
|
|
105
|
+
require 'yaml'
|
|
106
|
+
cfg = YAML.load_file(HERE + @yaml_config)[:generate_module]
|
|
107
|
+
@path_src = cfg[:defaults][:path_src] if @path_src.nil?
|
|
108
|
+
@path_inc = cfg[:defaults][:path_inc] if @path_inc.nil?
|
|
109
|
+
@path_tst = cfg[:defaults][:path_tst] if @path_tst.nil?
|
|
110
|
+
@update_svn = cfg[:defaults][:update_svn] if @update_svn.nil?
|
|
111
|
+
@extra_inc = cfg[:includes]
|
|
112
|
+
@boilerplates = cfg[:boilerplates]
|
|
113
|
+
else
|
|
114
|
+
@boilerplates = {}
|
|
115
|
+
end
|
|
116
|
+
|
|
117
|
+
# Create default file paths if none were provided
|
|
118
|
+
@path_src = HERE + "../src/" if @path_src.nil?
|
|
119
|
+
@path_inc = @path_src if @path_inc.nil?
|
|
120
|
+
@path_tst = HERE + "../test/" if @path_tst.nil?
|
|
121
|
+
@path_src += '/' unless (@path_src[-1] == 47)
|
|
122
|
+
@path_inc += '/' unless (@path_inc[-1] == 47)
|
|
123
|
+
@path_tst += '/' unless (@path_tst[-1] == 47)
|
|
124
|
+
@pattern = 'src' if @pattern.nil?
|
|
125
|
+
@includes = { :src => [], :inc => [], :tst => [] }
|
|
126
|
+
@includes.merge!(@extra_inc) unless @extra_inc.nil?
|
|
127
|
+
|
|
128
|
+
#create triad definition
|
|
129
|
+
TRIAD = [ { :ext => '.c', :path => @path_src, :template => TEMPLATE_SRC, :inc => :src, :boilerplate => @boilerplates[:src] },
|
|
130
|
+
{ :ext => '.h', :path => @path_inc, :template => TEMPLATE_INC, :inc => :inc, :boilerplate => @boilerplates[:inc] },
|
|
131
|
+
{ :ext => '.c', :path => @path_tst+'Test', :template => TEMPLATE_TST, :inc => :tst, :boilerplate => @boilerplates[:tst] },
|
|
132
|
+
]
|
|
133
|
+
|
|
134
|
+
#prepare the pattern for use
|
|
135
|
+
@patterns = PATTERNS[@pattern.downcase]
|
|
136
|
+
raise "ERROR: The design pattern specified isn't one that I recognize!" if @patterns.nil?
|
|
137
|
+
|
|
138
|
+
# Assemble the path/names of the files we need to work with.
|
|
139
|
+
files = []
|
|
140
|
+
TRIAD.each do |triad|
|
|
141
|
+
@patterns.each_pair do |pattern_file, pattern_traits|
|
|
142
|
+
files << {
|
|
143
|
+
:path => "#{triad[:path]}#{@module_name}#{pattern_file}#{triad[:ext]}",
|
|
144
|
+
:name => "#{@module_name}#{pattern_file}",
|
|
145
|
+
:template => triad[:template],
|
|
146
|
+
:boilerplate => triad[:boilerplate],
|
|
147
|
+
:includes => case(triad[:inc])
|
|
148
|
+
when :src then @includes[:src] | pattern_traits[:inc].map{|f| f % [@module_name]}
|
|
149
|
+
when :inc then @includes[:inc]
|
|
150
|
+
when :tst then @includes[:tst] | pattern_traits[:inc].map{|f| "Mock#{f}"% [@module_name]}
|
|
151
|
+
end
|
|
152
|
+
}
|
|
153
|
+
end
|
|
154
|
+
end
|
|
155
|
+
|
|
156
|
+
# destroy files if that was what was requested
|
|
157
|
+
if @destroy
|
|
158
|
+
files.each do |filespec|
|
|
159
|
+
file = filespec[:path]
|
|
160
|
+
if File.exist?(file)
|
|
161
|
+
if @update_svn
|
|
162
|
+
`svn delete \"#{file}\" --force`
|
|
163
|
+
puts "File #{file} deleted and removed from source control"
|
|
164
|
+
else
|
|
165
|
+
FileUtils.remove(file)
|
|
166
|
+
puts "File #{file} deleted"
|
|
167
|
+
end
|
|
168
|
+
else
|
|
169
|
+
puts "File #{file} does not exist so cannot be removed."
|
|
170
|
+
end
|
|
171
|
+
end
|
|
172
|
+
puts "Destroy Complete"
|
|
173
|
+
exit
|
|
174
|
+
end
|
|
175
|
+
|
|
176
|
+
#Abort if any module already exists
|
|
177
|
+
files.each do |file|
|
|
178
|
+
raise "ERROR: File #{file[:name]} already exists. Exiting." if File.exist?(file[:path])
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
# Create Source Modules
|
|
182
|
+
files.each_with_index do |file, i|
|
|
183
|
+
File.open(file[:path], 'w') do |f|
|
|
184
|
+
f.write(file[:boilerplate] % [file[:name]]) unless file[:boilerplate].nil?
|
|
185
|
+
f.write(file[:template] % [ file[:name],
|
|
186
|
+
file[:includes].map{|f| "#include \"#{f}\"\n"}.join,
|
|
187
|
+
file[:name].upcase ]
|
|
188
|
+
)
|
|
189
|
+
end
|
|
190
|
+
if (@update_svn)
|
|
191
|
+
`svn add \"#{file[:path]}\"`
|
|
192
|
+
if $?.exitstatus == 0
|
|
193
|
+
puts "File #{file[:path]} created and added to source control"
|
|
194
|
+
else
|
|
195
|
+
puts "File #{file[:path]} created but FAILED adding to source control!"
|
|
196
|
+
end
|
|
197
|
+
else
|
|
198
|
+
puts "File #{file[:path]} created"
|
|
199
|
+
end
|
|
200
|
+
end
|
|
201
|
+
|
|
202
|
+
puts 'Generate Complete'
|