forked from freudenreichan/info2Praktikum-DobleSpiel
Merge branch 'main' of https://git.efi.th-nuernberg.de/gitea/turtschinba100320/info2Praktikum-DobleSpielBastiBjoern
This commit is contained in:
commit
ce50ae30fa
13
makefile
13
makefile
@ -32,18 +32,23 @@ doble : main.o $(program_obj_files)
|
||||
$(program_obj_filesobj_files): %.o: %.c
|
||||
$(CC) -c $(FLAGS) $^ -o $@
|
||||
|
||||
numbers.o: numbers.c
|
||||
$(CC) -c $(CFLAGS) numbers.c
|
||||
|
||||
# --------------------------
|
||||
# Unit Tests
|
||||
# --------------------------
|
||||
unitTests:
|
||||
echo "needs to be implemented"
|
||||
|
||||
|
||||
numbersTests: numbers.o numbersTests.c $(unityfolder)/unity.c
|
||||
$(CC) $(CFLAGS) -I$(unityfolder) -o runNumbersTests numbersTests.c numbers.o $(unityfolder)/unity.c
|
||||
|
||||
# --------------------------
|
||||
# Clean
|
||||
# --------------------------
|
||||
clean:
|
||||
ifeq ($(OS),Windows_NT)
|
||||
del /f *.o doble
|
||||
del /f *.o doble *.exe
|
||||
else
|
||||
rm -f *.o doble
|
||||
rm -f *.o doble *runNumbersTests
|
||||
endif
|
||||
107
numbersTests.c
Normal file
107
numbersTests.c
Normal file
@ -0,0 +1,107 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include "numbers.h"
|
||||
#include "unity.h"
|
||||
|
||||
//Initialisierung
|
||||
void setUp(void){}
|
||||
void tearDown(void){}
|
||||
|
||||
// Hilfsfunktion: zählt Vorkommen eines Werts
|
||||
static unsigned int countOccurrences(unsigned int* arr, unsigned int n, unsigned int value)
|
||||
{
|
||||
unsigned int count = 0;
|
||||
for (unsigned int i = 0; i < n; i++)
|
||||
if (arr[i] == value)
|
||||
count++;
|
||||
return count;
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// Test 1: createNumbers erzeugt ein Array der richtigen Größe
|
||||
// ---------------------------------------------------------------------------
|
||||
void test_createNumbers_returns_valid_array(void)
|
||||
{
|
||||
unsigned int n = 50;
|
||||
unsigned int* arr = createNumbers(n);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(arr);
|
||||
|
||||
// Ein paar Werte prüfen (dürfen alles sein, nur kein Segfault)
|
||||
for (unsigned int i = 0; i < n; i++)
|
||||
TEST_ASSERT_TRUE(arr[i] >= 0);
|
||||
|
||||
free(arr);
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// Test 2: createNumbers erzeugt GENAU EIN Duplikat
|
||||
// ---------------------------------------------------------------------------
|
||||
void test_createNumbers_contains_exactly_one_duplicate(void)
|
||||
{
|
||||
unsigned int n = 50;
|
||||
unsigned int* arr = createNumbers(n);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(arr);
|
||||
|
||||
// zähle wie viele Werte doppelt vorkommen
|
||||
unsigned int duplicateValue = 0;
|
||||
unsigned int totalDuplicateAppearances = 0;
|
||||
|
||||
for (unsigned int i = 0; i < n; i++)
|
||||
{
|
||||
unsigned int c = countOccurrences(arr, n, arr[i]);
|
||||
if (c == 2) // genau zweimal → Bestandteil des Duplikats
|
||||
{
|
||||
duplicateValue = arr[i];
|
||||
totalDuplicateAppearances++;
|
||||
}
|
||||
}
|
||||
|
||||
// Wenn genau eine Zahl doppelt vorkommt,
|
||||
// finden wir sie zweimal → totalDuplicateAppearances == 2
|
||||
TEST_ASSERT_EQUAL_UINT(2, totalDuplicateAppearances);
|
||||
|
||||
free(arr);
|
||||
}
|
||||
// ---------------------------------------------------------------------------
|
||||
// Test 3: getDuplicated findet genau die richtige doppelte Zahl
|
||||
// ---------------------------------------------------------------------------
|
||||
void test_getDuplicated_finds_correct_duplicate(void)
|
||||
{
|
||||
unsigned int n = 50;
|
||||
unsigned int* arr = createNumbers(n);
|
||||
TEST_ASSERT_NOT_NULL(arr);
|
||||
|
||||
// Ermittle das Duplikat manuell
|
||||
unsigned int expected = 0;
|
||||
|
||||
for (unsigned int i = 0; i < n; i++)
|
||||
{
|
||||
if (countOccurrences(arr, n, arr[i]) == 2)
|
||||
{
|
||||
expected = arr[i];
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
unsigned int result = getDuplicate(arr, n);
|
||||
|
||||
TEST_ASSERT_EQUAL_UINT(expected, result);
|
||||
|
||||
free(arr);
|
||||
}
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
// main() für Unity
|
||||
// ---------------------------------------------------------------------------
|
||||
int main(void)
|
||||
{
|
||||
UNITY_BEGIN();
|
||||
|
||||
RUN_TEST(test_createNumbers_returns_valid_array);
|
||||
RUN_TEST(test_createNumbers_contains_exactly_one_duplicate);
|
||||
RUN_TEST(test_getDuplicated_finds_correct_duplicate);
|
||||
|
||||
return UNITY_END();
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user