From fafb1265a6e6f774fb313bbc1e4eb5f942e55e4f Mon Sep 17 00:00:00 2001 From: fdai7514 Date: Fri, 10 Feb 2023 21:07:22 +0100 Subject: [PATCH 1/4] implement function calculatorSquare() --- project.yml | 101 ++++++++++++++++++++++++++++++++++ src/calculatorSquare.c | 2 + src/calculatorSquare.h | 8 +++ src/main.c | 17 +++++- tests/support/.gitkeep | 0 tests/test_calculatorSquare.c | 20 +++++++ 6 files changed, 145 insertions(+), 3 deletions(-) create mode 100644 project.yml create mode 100644 src/calculatorSquare.c create mode 100644 src/calculatorSquare.h create mode 100644 tests/support/.gitkeep create mode 100644 tests/test_calculatorSquare.c diff --git a/project.yml b/project.yml new file mode 100644 index 0000000..640cb8f --- /dev/null +++ b/project.yml @@ -0,0 +1,101 @@ +--- + +# Notes: +# Sample project C code is not presently written to produce a release artifact. +# As such, release build options are disabled. +# This sample, therefore, only demonstrates running a collection of unit tests. + +:project: + :use_exceptions: FALSE + :use_test_preprocessor: TRUE + :use_auxiliary_dependencies: TRUE + :build_root: build +# :release_build: TRUE + :test_file_prefix: test_ + :which_ceedling: gem + :ceedling_version: 0.31.1 + :default_tasks: + - test:all + +#:test_build: +# :use_assembly: TRUE + +#:release_build: +# :output: MyApp.out +# :use_assembly: FALSE + +:environment: + +:extension: + :executable: .out + +:paths: + :test: + - +:tests/** + - -:tests/support + :source: + - src/** + :support: + - tests/support + :libraries: [] + +:defines: + # in order to add common defines: + # 1) remove the trailing [] from the :common: section + # 2) add entries to the :common: section (e.g. :test: has TEST defined) + :common: &common_defines [] + :test: + - *common_defines + - TEST + :test_preprocess: + - *common_defines + - TEST + +:cmock: + :mock_prefix: mock_ + :when_no_prototypes: :warn + :enforce_strict_ordering: TRUE + :plugins: + - :ignore + - :callback + :treat_as: + uint8: HEX8 + uint16: HEX16 + uint32: UINT32 + int8: INT8 + bool: UINT8 + +# Add -gcov to the plugins list to make sure of the gcov plugin +# You will need to have gcov and gcovr both installed to make it work. +# For more information on these options, see docs in plugins/gcov +:gcov: + :reports: + - HtmlDetailed + :gcovr: + :html_medium_threshold: 75 + :html_high_threshold: 90 + +#:tools: +# Ceedling defaults to using gcc for compiling, linking, etc. +# As [:tools] is blank, gcc will be used (so long as it's in your system path) +# See documentation to configure a given toolchain for use + +# LIBRARIES +# These libraries are automatically injected into the build process. Those specified as +# common will be used in all types of builds. Otherwise, libraries can be injected in just +# tests or releases. These options are MERGED with the options in supplemental yaml files. +:libraries: + :placement: :end + :flag: "-l${1}" + :path_flag: "-L ${1}" + :system: [] # for example, you might list 'm' to grab the math library + :test: [] + :release: [] + +:plugins: + :load_paths: + - "#{Ceedling.load_path}" + :enabled: + - stdout_pretty_tests_report + - module_generator +... diff --git a/src/calculatorSquare.c b/src/calculatorSquare.c new file mode 100644 index 0000000..bca42f6 --- /dev/null +++ b/src/calculatorSquare.c @@ -0,0 +1,2 @@ +#include "calculatorSquare.h" +float calculatorSquare(float x){return x*x;} diff --git a/src/calculatorSquare.h b/src/calculatorSquare.h new file mode 100644 index 0000000..bbc1bb5 --- /dev/null +++ b/src/calculatorSquare.h @@ -0,0 +1,8 @@ +#ifndef CALCULATORSQUARE_H +#define CALCULATORSQUARE_H +#include +#include +float calculatorSquare(float x); + + +#endif // CALCULATORSQUARE_H diff --git a/src/main.c b/src/main.c index a3a8e04..1de73d5 100644 --- a/src/main.c +++ b/src/main.c @@ -1,4 +1,15 @@ -#include -int main(){ -return 0; +#include "calculatorSquare.c" + + +int main() +{ + float num, square; + + printf("number: "); + scanf("%f", &num); + + square = calculatorSquare(num); + + printf("answer: %f", square); + return 0; } diff --git a/tests/support/.gitkeep b/tests/support/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/tests/test_calculatorSquare.c b/tests/test_calculatorSquare.c new file mode 100644 index 0000000..3bbf2b1 --- /dev/null +++ b/tests/test_calculatorSquare.c @@ -0,0 +1,20 @@ +#ifdef TEST + +#include "unity.h" + +#include "calculatorSquare.h" + +void setUp(void) +{ +} + +void tearDown(void) +{ +} + +void test_calculatorSquare_NeedToImplement(void) +{ + TEST_IGNORE_MESSAGE("Need to Implement calculatorSquare"); +} + +#endif // TEST From 74527de98fdc8f2e7cdc4607c255f3c943bf1335 Mon Sep 17 00:00:00 2001 From: fdai7514 Date: Fri, 10 Feb 2023 21:11:51 +0100 Subject: [PATCH 2/4] implement unittest for calculatorSquare.c --- build-project.sh | 1 + tests/test_calculatorSquare.c | 20 +++++++++++++++++--- 2 files changed, 18 insertions(+), 3 deletions(-) diff --git a/build-project.sh b/build-project.sh index 43a0588..51cf723 100755 --- a/build-project.sh +++ b/build-project.sh @@ -1,4 +1,5 @@ clear +ceedling test:all cd src/ gcc main.c -o main ./main diff --git a/tests/test_calculatorSquare.c b/tests/test_calculatorSquare.c index 3bbf2b1..981dda0 100644 --- a/tests/test_calculatorSquare.c +++ b/tests/test_calculatorSquare.c @@ -2,7 +2,7 @@ #include "unity.h" -#include "calculatorSquare.h" +#include "calculatorSquare.c" void setUp(void) { @@ -12,9 +12,23 @@ void tearDown(void) { } -void test_calculatorSquare_NeedToImplement(void) +void test1_calculatorMultiply(void) { - TEST_IGNORE_MESSAGE("Need to Implement calculatorSquare"); + float p, a, e; + p = 26.24; + a = calculatorSquare(p); + e = p * p; + TEST_ASSERT_EQUAL_FLOAT(e, a); } +void test2_calculatorMultiply(void) +{ + float p, a, e; + p = 5; + a = calculatorSquare(p); + e = p * p; + TEST_ASSERT_EQUAL_FLOAT(e, a); +} + + #endif // TEST From 350eeafbe6fb816a16e92dba4300943be5c2b604 Mon Sep 17 00:00:00 2001 From: fdai7514 Date: Fri, 10 Feb 2023 21:14:26 +0100 Subject: [PATCH 3/4] refactoring: change variable names and format code in calculatorSquare.c --- src/calculatorSquare.c | 6 +++++- src/calculatorSquare.h | 2 +- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/calculatorSquare.c b/src/calculatorSquare.c index bca42f6..a58fe24 100644 --- a/src/calculatorSquare.c +++ b/src/calculatorSquare.c @@ -1,2 +1,6 @@ #include "calculatorSquare.h" -float calculatorSquare(float x){return x*x;} + +float calculatorSquare(float num) +{ + return num*num; +} diff --git a/src/calculatorSquare.h b/src/calculatorSquare.h index bbc1bb5..7f0efea 100644 --- a/src/calculatorSquare.h +++ b/src/calculatorSquare.h @@ -2,7 +2,7 @@ #define CALCULATORSQUARE_H #include #include -float calculatorSquare(float x); +float calculatorSquare(float num); #endif // CALCULATORSQUARE_H From fe9ed8154956cce61168f3cc3c24db445f197c6b Mon Sep 17 00:00:00 2001 From: fdai7514 Date: Fri, 10 Feb 2023 21:23:13 +0100 Subject: [PATCH 4/4] refactoring: change variable names in test_calculatorSquare.c --- src/calculatorSquare.c | 3 +++ tests/test_calculatorSquare.c | 26 ++++++++++++++------------ 2 files changed, 17 insertions(+), 12 deletions(-) diff --git a/src/calculatorSquare.c b/src/calculatorSquare.c index a58fe24..e28cd3b 100644 --- a/src/calculatorSquare.c +++ b/src/calculatorSquare.c @@ -1,4 +1,7 @@ #include "calculatorSquare.h" +// Note: +/* This Function may or may not be implemented in actual program, even if it is merged to the main branch. + If it is temporarily not included in the main Program, then this has a role in future Development of the Project */ float calculatorSquare(float num) { diff --git a/tests/test_calculatorSquare.c b/tests/test_calculatorSquare.c index 981dda0..2a610f6 100644 --- a/tests/test_calculatorSquare.c +++ b/tests/test_calculatorSquare.c @@ -3,6 +3,10 @@ #include "unity.h" #include "calculatorSquare.c" +// Note: +/* This Function may or may not be implemented in actual program, even if it is merged to the main branch. + If it is temporarily not included in the main Program, then this has a role in future Development of the Project */ + void setUp(void) { @@ -14,21 +18,19 @@ void tearDown(void) void test1_calculatorMultiply(void) { - float p, a, e; - p = 26.24; - a = calculatorSquare(p); - e = p * p; - TEST_ASSERT_EQUAL_FLOAT(e, a); + float num, actual, expected; //Arrange + num = 26.24; + expected = num * num; + actual = calculatorSquare(num); //Act + TEST_ASSERT_EQUAL_FLOAT(expected, actual); //Assert } void test2_calculatorMultiply(void) { - float p, a, e; - p = 5; - a = calculatorSquare(p); - e = p * p; - TEST_ASSERT_EQUAL_FLOAT(e, a); + float num, actual, expected; //Arrange + num = 5; + expected = num * num; + actual = calculatorSquare(num); //Act + TEST_ASSERT_EQUAL_FLOAT(expected, actual); //Assert } - - #endif // TEST