diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 9c0fbb9..55b0e37 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -41,7 +41,7 @@ jobs: - name: Test working-directory: ${{env.build_path}} - run: ctest + run: ctest --output-on-failure - name: Run examples working-directory: ${{env.build_path}} diff --git a/tests/sorts/bubble_sort.f90 b/tests/sorts/bubble_sort.f90 new file mode 100644 index 0000000..2ce0f00 --- /dev/null +++ b/tests/sorts/bubble_sort.f90 @@ -0,0 +1,107 @@ +!> Test program for the Bubble Sort algorithm +!! +!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) +!! in Pull Request: #29 +!! https://github.com/TheAlgorithms/Fortran/pull/29 +!! +!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request +!! addressing bugs/corrections to this file. Thank you! +!! +!! This program tests the bubble_sort_module for correct sorting behavior. + +program tests_bubble_sort + use bubble_sort_module + implicit none + real, dimension(:), allocatable :: array, expected + + ! Run test cases + call test_sorted_array() + call test_reverse_sorted_array() + call test_unsorted_array() + call test_array_with_repeated_elements() + call test_array_with_identical_elements() + call test_single_element_array() + call test_empty_array() + + print *, "All tests completed." + +contains + + ! Test case 1: Already sorted array + subroutine test_sorted_array() + array = (/1.0, 2.0, 3.0, 4.0, 5.0/) + expected = array + call run_test(array, expected, "Test 1: Already sorted array") + end subroutine test_sorted_array + + ! Test case 2: Reverse sorted array + subroutine test_reverse_sorted_array() + array = (/5.0, 4.0, 3.0, 2.0, 1.0/) + expected = (/1.0, 2.0, 3.0, 4.0, 5.0/) + call run_test(array, expected, "Test 2: Reverse sorted array") + end subroutine test_reverse_sorted_array + + ! Test case 3: Unsorted array + subroutine test_unsorted_array() + array = (/3.5, 1.2, 4.8, 2.7, 5.0/) + expected = (/1.2, 2.7, 3.5, 4.8, 5.0/) + call run_test(array, expected, "Test 3: Unsorted array") + end subroutine test_unsorted_array + + ! Test case 4: Array with repeated elements + subroutine test_array_with_repeated_elements() + array = (/3.0, 1.0, 2.0, 3.0, 4.0, 3.0/) + expected = (/1.0, 2.0, 3.0, 3.0, 3.0, 4.0/) + call run_test(array, expected, "Test 4: Array with repeated elements") + end subroutine test_array_with_repeated_elements + + ! Test case 5: Array with identical elements + subroutine test_array_with_identical_elements() + array = (/7.0, 7.0, 7.0, 7.0, 7.0/) + expected = array + call run_test(array, expected, "Test 5: Array with identical elements") + end subroutine test_array_with_identical_elements + + ! Test case 6: Single element array + subroutine test_single_element_array() + array = (/42.0/) + expected = array + call run_test(array, expected, "Test 6: Single element array") + end subroutine test_single_element_array + + ! Test case 7: Empty array + subroutine test_empty_array() + if (allocated(array)) deallocate (array) + if (allocated(expected)) deallocate (expected) + allocate (array(0)) + allocate (expected(0)) + call run_test(array, expected, "Test 7: Empty array") + end subroutine test_empty_array + + !> Subroutine to run the bubble sort test + subroutine run_test(array, expected, test_name) + real, dimension(:), intent(inout) :: array + real, dimension(:), intent(in) :: expected + character(len=*), intent(in) :: test_name + real :: tolerance + + ! Call bubble_sort in module + call bubble_sort(array) + + ! Set an appropriate tolerance value + tolerance = 1.0e-6 + + ! Assert if the sorted values are sufficiently close to the expected array otherwise report failure + if (all(abs(array - expected) < tolerance)) then + print *, test_name, " PASSED" + else + print *, test_name, " FAILED" + print *, "Expected: ", expected + print *, "Got: ", array + stop 1 + end if + + end subroutine run_test + +end program tests_bubble_sort + diff --git a/tests/sorts/gnome_sort.f90 b/tests/sorts/gnome_sort.f90 new file mode 100644 index 0000000..4fab834 --- /dev/null +++ b/tests/sorts/gnome_sort.f90 @@ -0,0 +1,111 @@ +!> Test program for the Gnome Sort algorithm +!! +!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) +!! in Pull Request: #9 +!! https://github.com/TheAlgorithms/Fortran/pull/9 +!! +!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request +!! addressing bugs/corrections to this file. Thank you! +!! +!! This program provides additional test cases to validate the gnome_sort_module. + +program tests_gnome_sort + + use gnome_sort_module + implicit none + integer, dimension(:), allocatable :: array, expected + + ! Run test cases + call test_repeated_elements() + call test_already_sorted() + call test_reverse_sorted() + call test_negative_numbers() + call test_single_element() + call test_identical_elements() + call test_alternating_values() + call test_empty_array() + + print *, "All tests completed." + +contains + + ! Test case 1: Array with repeated elements + subroutine test_repeated_elements() + array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) + expected = (/1, 1, 3, 3, 3, 5, 5, 5, 7, 7, 8, 10/) + call run_test(array, expected, "Test 1: Array with repeated elements") + end subroutine test_repeated_elements + + ! Test case 2: Already sorted array + subroutine test_already_sorted() + array = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13/) + call run_test(array, expected, "Test 2: Already sorted array") + end subroutine test_already_sorted + + ! Test case 3: Reverse sorted array + subroutine test_reverse_sorted() + array = (/11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11/) + call run_test(array, expected, "Test 3: Reverse sorted array") + end subroutine test_reverse_sorted + + ! Test case 4: Array with all negative numbers + subroutine test_negative_numbers() + array = (/-1, -5, -4, -7, -2, -1, -1, -9, -2/) + expected = (/-9, -7, -5, -4, -2, -2, -1, -1, -1/) + call run_test(array, expected, "Test 4: Array with all negative numbers") + end subroutine test_negative_numbers + + ! Test case 5: Single element array + subroutine test_single_element() + array = (/73/) + expected = (/73/) + call run_test(array, expected, "Test 5: Single element array") + end subroutine test_single_element + + ! Test case 6: Array with identical elements + subroutine test_identical_elements() + array = (/8, 8, 8, 8, 8/) + expected = (/8, 8, 8, 8, 8/) + call run_test(array, expected, "Test 6: Array with identical elements") + end subroutine test_identical_elements + + ! Test case 7: Array with alternating high and low values + subroutine test_alternating_values() + array = (/1, 999, 2, 600, 3, 950/) + expected = (/1, 2, 3, 600, 950, 999/) + call run_test(array, expected, "Test 7: Array with alternating high and low values") + end subroutine test_alternating_values + + ! Test case 8: Empty array + subroutine test_empty_array() + if (allocated(array)) deallocate (array) + if (allocated(expected)) deallocate (expected) + allocate (array(0)) + allocate (expected(0)) + call run_test(array, expected, "Test 8: Empty array") + end subroutine test_empty_array + + !> Subroutine to run the heap sort test + subroutine run_test(array, expected, test_name) + integer, dimension(:), intent(inout) :: array + integer, dimension(:), intent(in) :: expected + character(len=*), intent(in) :: test_name + + ! Call gnome_sort in module + call gnome_sort(array) + + ! Assert that the sorted array matches the expected array otherwise report failure for ctest + if (all(array == expected)) then + print *, test_name, " PASSED" + else + print *, test_name, " FAILED" + print *, "Expected: ", expected + print *, "Got: ", array + stop 1 + end if + + end subroutine run_test + +end program tests_gnome_sort diff --git a/tests/sorts/heap_sort.f90 b/tests/sorts/heap_sort.f90 new file mode 100644 index 0000000..2cf19dd --- /dev/null +++ b/tests/sorts/heap_sort.f90 @@ -0,0 +1,114 @@ +!> Test program for the Heap Sort algorithm +!! +!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) +!! in Pull Request: #8 +!! https://github.com/TheAlgorithms/Fortran/pull/8 +!! +!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request +!! addressing bugs/corrections to this file. Thank you! +!! +!! This program provides additional test cases to validate the heap_sort_module. + +program tests_heap_sort + + use heap_sort_module + implicit none + integer, dimension(:), allocatable :: array, expected + + ! Run test cases + call test_repeated_elements() + call test_already_sorted() + call test_reverse_sorted() + call test_negative_numbers() + call test_single_element() + call test_identical_elements() + call test_alternating_values() + call test_empty_array() + + print *, "All tests completed." + +contains + + ! Test case 1: Array with repeated elements + subroutine test_repeated_elements() + array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) + expected = (/1, 1, 3, 3, 3, 5, 5, 5, 7, 7, 8, 10/) + call run_test(array, expected, "Test 1: Array with repeated elements") + end subroutine test_repeated_elements + + ! Test case 2: Already sorted array + subroutine test_already_sorted() + array = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10/) + call run_test(array, expected, "Test 2: Already sorted array") + end subroutine test_already_sorted + + ! Test case 3: Reverse sorted array + subroutine test_reverse_sorted() + array = (/9, 8, 7, 6, 5, 4, 3, 2, 1/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9/) + call run_test(array, expected, "Test 3: Reverse sorted array") + end subroutine test_reverse_sorted + + ! Test case 4: Array with all negative numbers + subroutine test_negative_numbers() + array = (/-110, -550, -430, -700, -20, -10, -150, -90, -250/) + expected = (/-700, -550, -430, -250, -150, -110, -90, -20, -10/) + call run_test(array, expected, "Test 4: Array with all negative numbers") + end subroutine test_negative_numbers + + ! Test case 5: Single element array + subroutine test_single_element() + array = (/43/) + expected = (/43/) + call run_test(array, expected, "Test 5: Single element array") + end subroutine test_single_element + + ! Test case 6: Array with identical elements + subroutine test_identical_elements() + array = (/7, 7, 7, 7, 7/) + expected = (/7, 7, 7, 7, 7/) + call run_test(array, expected, "Test 6: Array with identical elements") + end subroutine test_identical_elements + + ! Test case 7: Array with alternating high and low values + subroutine test_alternating_values() + array = (/1, 1000, 2, 999, 3, 998/) + expected = (/1, 2, 3, 998, 999, 1000/) + call run_test(array, expected, "Test 7: Array with alternating high and low values") + end subroutine test_alternating_values + + ! Test case 8: Empty array + subroutine test_empty_array() + if (allocated(array)) deallocate (array) + if (allocated(expected)) deallocate (expected) + allocate (array(0)) + allocate (expected(0)) + call run_test(array, expected, "Test 8: Empty array") + end subroutine test_empty_array + + !> Subroutine to run the heap sort test + subroutine run_test(array, expected, test_name) + integer, dimension(:), intent(inout) :: array + integer, dimension(:), intent(in) :: expected + character(len=*), intent(in) :: test_name + integer :: n + + n = size(array) + + ! Call heap_sort in module + call heap_sort(array, n) + + ! Assert that the sorted array matches the expected array otherwise report failure for ctest + if (all(array == expected)) then + print *, test_name, " PASSED" + else + print *, test_name, " FAILED" + print *, "Expected: ", expected + print *, "Got: ", array + stop 1 + end if + + end subroutine run_test + +end program tests_heap_sort diff --git a/tests/sorts/merge_sort.f90 b/tests/sorts/merge_sort.f90 new file mode 100644 index 0000000..b27f70b --- /dev/null +++ b/tests/sorts/merge_sort.f90 @@ -0,0 +1,114 @@ +!> Test program for the Merge Sort algorithm +!! +!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) +!! in Pull Request: #7 +!! https://github.com/TheAlgorithms/Fortran/pull/7 +!! +!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request +!! addressing bugs/corrections to this file. Thank you! +!! +!! This program provides additional test cases to validate the merge_sort_module. + +program tests_merge_sort + + use merge_sort_module + implicit none + integer, dimension(:), allocatable :: array, expected + + ! Run test cases + call test_repeated_elements() + call test_already_sorted() + call test_reverse_sorted() + call test_negative_numbers() + call test_single_element() + call test_identical_elements() + call test_alternating_values() + call test_empty_array() + + print *, "All tests completed." + +contains + + ! Test case 1: Array with repeated elements + subroutine test_repeated_elements() + array = (/4, 2, 7, 3, 1, 4, 9, 5, 10, 9, 2, 1/) + expected = (/1, 1, 2, 2, 3, 4, 4, 5, 7, 9, 9, 10/) + call run_test(array, expected, "Test 1: Array with repeated elements") + end subroutine test_repeated_elements + + ! Test case 2: Already sorted array + subroutine test_already_sorted() + array = (/1, 2, 3, 4, 5, 6, 7, 8/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8/) + call run_test(array, expected, "Test 2: Already sorted array") + end subroutine test_already_sorted + + ! Test case 3: Reverse sorted array + subroutine test_reverse_sorted() + array = (/8, 7, 6, 5, 4, 3, 2, 1/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8/) + call run_test(array, expected, "Test 3: Reverse sorted array") + end subroutine test_reverse_sorted + + ! Test case 4: Array with all negative numbers + subroutine test_negative_numbers() + array = (/-11, -55, -43, -70, -2, -1, -15, -9/) + expected = (/-70, -55, -43, -15, -11, -9, -2, -1/) + call run_test(array, expected, "Test 4: Array with all negative numbers") + end subroutine test_negative_numbers + + ! Test case 5: Single element array + subroutine test_single_element() + array = (/62/) + expected = (/62/) + call run_test(array, expected, "Test 5: Single element array") + end subroutine test_single_element + + ! Test case 6: Array with identical elements + subroutine test_identical_elements() + array = (/4, 4, 4, 4, 4/) + expected = (/4, 4, 4, 4, 4/) + call run_test(array, expected, "Test 6: Array with identical elements") + end subroutine test_identical_elements + + ! Test case 7: Array with alternating high and low values + subroutine test_alternating_values() + array = (/10, 2000, 20, 888, 30, 798/) + expected = (/10, 20, 30, 798, 888, 2000/) + call run_test(array, expected, "Test 7: Array with alternating high and low values") + end subroutine test_alternating_values + + ! Test case 8: Empty array + subroutine test_empty_array() + if (allocated(array)) deallocate (array) + if (allocated(expected)) deallocate (expected) + allocate (array(0)) + allocate (expected(0)) + call run_test(array, expected, "Test 8: Empty array") + end subroutine test_empty_array + + !> Subroutine to run the merge sort test + subroutine run_test(array, expected, test_name) + integer, dimension(:), intent(inout) :: array + integer, dimension(:), intent(in) :: expected + character(len=*), intent(in) :: test_name + integer :: n + + n = size(array) + + ! Call merge_sort in module + call merge_sort(array, n) + + ! Assert that the sorted array matches the expected array otherwise report failure for ctest + if (all(array == expected)) then + print *, test_name, " PASSED" + else + print *, test_name, " FAILED" + print *, "Expected: ", expected + print *, "Got: ", array + stop 1 + end if + + end subroutine run_test + +end program tests_merge_sort diff --git a/tests/sorts/quick_sort.f90 b/tests/sorts/quick_sort.f90 new file mode 100644 index 0000000..c574a4b --- /dev/null +++ b/tests/sorts/quick_sort.f90 @@ -0,0 +1,114 @@ +!> Test program for the Quick Sort algorithm +!! +!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) +!! in Pull Request: #10 +!! https://github.com/TheAlgorithms/Fortran/pull/10 +!! +!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request +!! addressing bugs/corrections to this file. Thank you! +!! +!! This program provides additional test cases to validate the quick_sort_module. + +program tests_quick_sort + + use quick_sort_module + implicit none + integer, dimension(:), allocatable :: array, expected + + ! Run test cases + call test_repeated_elements() + call test_already_sorted() + call test_reverse_sorted() + call test_negative_numbers() + call test_single_element() + call test_identical_elements() + call test_alternating_values() + call test_empty_array() + + print *, "All tests completed." + +contains + + ! Test case 1: Array with repeated elements + subroutine test_repeated_elements() + array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) + expected = (/1, 1, 3, 3, 3, 5, 5, 5, 7, 7, 8, 10/) + call run_test(array, expected, "Test 1: Array with repeated elements") + end subroutine test_repeated_elements + + ! Test case 2: Already sorted array + subroutine test_already_sorted() + array = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12/) + call run_test(array, expected, "Test 2: Already sorted array") + end subroutine test_already_sorted + + ! Test case 3: Reverse sorted array + subroutine test_reverse_sorted() + array = (/10, 9, 8, 7, 6, 5, 4, 3, 2, 1/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10/) + call run_test(array, expected, "Test 3: Reverse sorted array") + end subroutine test_reverse_sorted + + ! Test case 4: Array with all negative numbers + subroutine test_negative_numbers() + array = (/-1, -5, -4, -7, -2, -1, -1, -9, -2/) + expected = (/-9, -7, -5, -4, -2, -2, -1, -1, -1/) + call run_test(array, expected, "Test 4: Array with all negative numbers") + end subroutine test_negative_numbers + + ! Test case 5: Single element array + subroutine test_single_element() + array = (/23/) + expected = (/23/) + call run_test(array, expected, "Test 5: Single element array") + end subroutine test_single_element + + ! Test case 6: Array with identical elements + subroutine test_identical_elements() + array = (/-9, -9, -9, -9, -9/) + expected = (/-9, -9, -9, -9, -9/) + call run_test(array, expected, "Test 6: Array with identical elements") + end subroutine test_identical_elements + + ! Test case 7: Array with alternating high and low values + subroutine test_alternating_values() + array = (/1, 999, 2, 600, 3, 950/) + expected = (/1, 2, 3, 600, 950, 999/) + call run_test(array, expected, "Test 7: Array with alternating high and low values") + end subroutine test_alternating_values + + ! Test case 8: Empty array + subroutine test_empty_array() + if (allocated(array)) deallocate (array) + if (allocated(expected)) deallocate (expected) + allocate (array(0)) + allocate (expected(0)) + call run_test(array, expected, "Test 8: Empty array") + end subroutine test_empty_array + + !> Subroutine to run the quick sort test + subroutine run_test(array, expected, test_name) + integer, dimension(:), intent(inout) :: array + integer, dimension(:), intent(in) :: expected + character(len=*), intent(in) :: test_name + integer :: n + + n = size(array) + + ! Call quick_sort in module + call quick_sort(array, 1, n) ! (1: low bound , n: high bound) of the array + + ! Assert that the sorted array matches the expected array otherwise report failure for ctest + if (all(array == expected)) then + print *, test_name, " PASSED" + else + print *, test_name, " FAILED" + print *, "Expected: ", expected + print *, "Got: ", array + stop 1 + end if + + end subroutine run_test + +end program tests_quick_sort diff --git a/tests/sorts/radix_sort.f90 b/tests/sorts/radix_sort.f90 new file mode 100644 index 0000000..fb9e65e --- /dev/null +++ b/tests/sorts/radix_sort.f90 @@ -0,0 +1,141 @@ +!> Test program for the Radix Sort algorithm +!! +!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) +!! in Pull Request: #11 +!! https://github.com/TheAlgorithms/Fortran/pull/11 +!! +!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request +!! addressing bugs/corrections to this file. Thank you! +!! +!! This program provides additional test cases to validate the radix_sort_module. +!! The radix (base) parameter affects the internal digit processing for sorting, but the final output is always in decimal form. + +program tests_radix_sort + use radix_sort_module + implicit none + integer, dimension(:), allocatable :: array, expected + integer, parameter :: base10 = 10, base2 = 2, base16 = 16 + + ! Run test cases + call test_base10() + call test_base2() + call test_base16() + call test_repeated_elements() + call test_already_sorted() + call test_reverse_sorted() + call test_negative_numbers() + call test_single_element() + call test_identical_elements() + call test_alternating_values() + call test_empty_array() + + print *, "All tests completed." + +contains + + ! Test 1: sort with Base 10 + subroutine test_base10() + array = (/170, 45, 75, 90, 802, 24, 2, 66, 15, 40/) + expected = (/2, 15, 24, 40, 45, 66, 75, 90, 170, 802/) + call run_test(array, expected, base10, "Test 1: Base 10") + end subroutine test_base10 + + ! Test 2: Sort with Base 2 + subroutine test_base2() + array = (/10, 13, 9, 14, 2, 5, 15, 6, 8, 1/) ! Binary values as decimal + expected = (/1, 2, 5, 6, 8, 9, 10, 13, 14, 15/) + call run_test(array, expected, base2, "Test 2 Base 2") + end subroutine test_base2 + + ! Test 3: Sorth with Base 16 + subroutine test_base16() + array = (/171, 31, 61, 255, 16, 5, 211, 42, 180, 0/) ! Hexadecimal values as decimal + expected = (/0, 5, 16, 31, 42, 61, 171, 180, 211, 255/) + call run_test(array, expected, base16, "Test 3: Base 16") + end subroutine test_base16 + + ! Test case 4: Array with repeated elements + subroutine test_repeated_elements() + array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) + expected = (/1, 1, 3, 3, 3, 5, 5, 5, 7, 7, 8, 10/) + call run_test(array, expected, base10, "Test 4: Array with repeated elements") + end subroutine test_repeated_elements + + ! Test case 5: Already sorted array + subroutine test_already_sorted() + array = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13/) + call run_test(array, expected, base10, "Test 5: Already sorted array") + end subroutine test_already_sorted + + ! Test 6: Reverse sorted array + subroutine test_reverse_sorted() + array = (/11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1/) + expected = (/1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11/) + call run_test(array, expected, base10, "Test 6: Reverse sorted array") + end subroutine test_reverse_sorted + + ! Test 7: Array with all negative numbers (Note: Radix Sort only handles non-negative integers) + subroutine test_negative_numbers() + array = (/-1, -5, -3, -7, -2, -12, -15, -4/) + expected = (/-1, -5, -3, -7, -2, -12, -15, -4/) + call run_test(array, expected, base10, "Test 7: Array with all negative numbers (handled as base 10)") + end subroutine test_negative_numbers + + ! Test 8: Single element array + subroutine test_single_element() + array = (/93/) + expected = (/93/) + call run_test(array, expected, base10, "Test 8: Single element array") + end subroutine test_single_element + + ! Test 9: Array with identical elements + subroutine test_identical_elements() + array = (/8, 8, 8, 8, 8/) + expected = (/8, 8, 8, 8, 8/) + call run_test(array, expected, base10, "Test 9: Array with identical elements") + end subroutine test_identical_elements + + ! Test 10: Array with alternating high and low values + subroutine test_alternating_values() + array = (/1, 999, 2, 600, 3, 950/) + expected = (/1, 2, 3, 600, 950, 999/) + call run_test(array, expected, base10, "Test 10: Array with alternating high and low values") + end subroutine test_alternating_values + + ! Test 11: Empty array + subroutine test_empty_array() + if (allocated(array)) deallocate (array) + if (allocated(expected)) deallocate (expected) + allocate (array(0)) + allocate (expected(0)) + call run_test(array, expected, base10, "Test 11: Empty array") + end subroutine test_empty_array + + !> Subroutine to run the radix sort test + subroutine run_test(array, expected, base, test_name) + integer, dimension(:), intent(inout) :: array + integer, dimension(:), intent(in) :: expected + integer, intent(in) :: base + character(len=*), intent(in) :: test_name + integer :: n + + n = size(array) + + ! Call radix_sort in module + ! The parameters specify the array to sort, its size, and the base for sorting. + call radix_sort(array, n, base) + + ! Assert that the sorted array matches the expected array otherwise report failure for ctest + if (all(array == expected)) then + print *, test_name, " PASSED" + else + print *, test_name, " FAILED" + print *, "Expected: ", expected + print *, "Got: ", array + stop 1 + end if + + end subroutine run_test + +end program tests_radix_sort diff --git a/tests/sorts/recursive_bubbe_sort.f90 b/tests/sorts/recursive_bubbe_sort.f90 new file mode 100644 index 0000000..b07b192 --- /dev/null +++ b/tests/sorts/recursive_bubbe_sort.f90 @@ -0,0 +1,110 @@ +!> Test program for the Bubble Sort algorithm +!! +!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) +!! in Pull Request: #29 +!! https://github.com/TheAlgorithms/Fortran/pull/29 +!! +!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request +!! addressing bugs/corrections to this file. Thank you! +!! +!! This program tests the recursive_bubble_sort_module for correct sorting behavior. + +program tests_recursive_bubble_sort + use recursive_bubble_sort_module + implicit none + real, dimension(:), allocatable :: array, expected + + ! Run test cases + call test_sorted_array() + call test_reverse_sorted_array() + call test_unsorted_array() + call test_array_with_repeated_elements() + call test_array_with_identical_elements() + call test_single_element_array() + call test_empty_array() + + print *, "All tests completed." + +contains + + ! Test case 1: Already sorted array + subroutine test_sorted_array() + array = (/1.0, 2.0, 3.0, 4.0, 5.0/) + expected = array + call run_test(array, expected, "Test 1: Already sorted array") + end subroutine test_sorted_array + + ! Test case 2: Reverse sorted array + subroutine test_reverse_sorted_array() + array = (/5.0, 4.0, 3.0, 2.0, 1.0/) + expected = (/1.0, 2.0, 3.0, 4.0, 5.0/) + call run_test(array, expected, "Test 2: Reverse sorted array") + end subroutine test_reverse_sorted_array + + ! Test case 3: Unsorted array + subroutine test_unsorted_array() + array = (/3.5, 1.2, 4.8, 2.7, 5.0/) + expected = (/1.2, 2.7, 3.5, 4.8, 5.0/) + call run_test(array, expected, "Test 3: Unsorted array") + end subroutine test_unsorted_array + + ! Test case 4: Array with repeated elements + subroutine test_array_with_repeated_elements() + array = (/3.0, 1.0, 2.0, 3.0, 4.0, 3.0/) + expected = (/1.0, 2.0, 3.0, 3.0, 3.0, 4.0/) + call run_test(array, expected, "Test 4: Array with repeated elements") + end subroutine test_array_with_repeated_elements + + ! Test case 5: Array with identical elements + subroutine test_array_with_identical_elements() + array = (/7.0, 7.0, 7.0, 7.0, 7.0/) + expected = array + call run_test(array, expected, "Test 5: Array with identical elements") + end subroutine test_array_with_identical_elements + + ! Test case 6: Single element array + subroutine test_single_element_array() + array = (/42.0/) + expected = array + call run_test(array, expected, "Test 6: Single element array") + end subroutine test_single_element_array + + ! Test case 7: Empty array + subroutine test_empty_array() + if (allocated(array)) deallocate (array) + if (allocated(expected)) deallocate (expected) + allocate (array(0)) + allocate (expected(0)) + call run_test(array, expected, "Test 7: Empty array") + end subroutine test_empty_array + + !> Subroutine to run the bubble sort test + subroutine run_test(array, expected, test_name) + real, dimension(:), intent(inout) :: array + real, dimension(:), intent(in) :: expected + character(len=*), intent(in) :: test_name + real :: tolerance + integer :: n + + n = size(array) + + ! Call bubble_sort in module + call recursive_bubble_sort(array, n) + + ! Set an appropriate tolerance value + tolerance = 1.0e-6 + + ! Assert if the sorted values are sufficiently close to the expected array otherwise report failure + if (all(abs(array - expected) < tolerance)) then + print *, test_name, " PASSED" + else + print *, test_name, " FAILED" + print *, "Expected: ", expected + print *, "Got: ", array + stop 1 + end if + + end subroutine run_test + +end program tests_recursive_bubble_sort + diff --git a/tests/sorts/tests_gnome_sort.f90 b/tests/sorts/tests_gnome_sort.f90 deleted file mode 100644 index d921c67..0000000 --- a/tests/sorts/tests_gnome_sort.f90 +++ /dev/null @@ -1,98 +0,0 @@ -!> Test program for the Gnome Sort algorithm -!! -!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) -!! in Pull Request: #09 -!! https://github.com/TheAlgorithms/Fortran/pull/9 -!! -!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request -!! addressing bugs/corrections to this file. Thank you! -!! -!! This program provides additional test cases to validate the gnome_sort_module. - -program tests_gnome_sort - - use gnome_sort_module - implicit none - integer, dimension(:), allocatable :: array - - ! Test 1: Repeated elements - print *, "Test 1: Array with repeated elements" - array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) - call run_test(array) - - ! Test 2: Already sorted array - print *, "Test 2: Already sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/1, 2, 3, 4, 5, 6, 7, 8/) - call run_test(array) - - ! Test 3: Reverse sorted array - print *, "Test 3: Reverse sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/8, 7, 6, 5, 4, 3, 2, 1/) - call run_test(array) - - ! Test 4: Array with all negative numbers - print *, "Test 4: Array with all negative numbers" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/-1, -5, -3, -7, -2, -12, -15, -4/) - call run_test(array) - - ! Test 5: Single element array - print *, "Test 5: Single element array" - if (allocated(array)) deallocate (array) - allocate (array(1)) - array = (/42/) - call run_test(array) - - ! Test 6: Array with identical elements - print *, "Test 6: Array with identical elements" - if (allocated(array)) deallocate (array) - allocate (array(5)) - array = (/7, 7, 7, 7, 7/) - call run_test(array) - - ! Test 7: Array with alternating high and low values - print *, "Test 7: Array with alternating high and low values" - if (allocated(array)) deallocate (array) - allocate (array(6)) - array = (/1, 1000, 2, 999, 3, 998/) - call run_test(array) - - ! Test 8: Empty array - print *, "Test 8: Empty array" - if (allocated(array)) deallocate (array) - allocate (array(0)) - call run_test(array) - -contains - - !> Subroutine to run and print the gnome sort test - subroutine run_test(array) - integer, dimension(:), intent(inout) :: array - integer :: n, i - - n = size(array) - - ! Print original array - print *, "Original array:" - do i = 1, n - print *, array(i) - end do - - ! Call gnome_sort - call gnome_sort(array) - - ! Print sorted array - print *, "Sorted array:" - do i = 1, n - print *, array(i) - end do - - print *, "" - end subroutine run_test - -end program tests_gnome_sort diff --git a/tests/sorts/tests_heap_sort.f90 b/tests/sorts/tests_heap_sort.f90 deleted file mode 100644 index 18b2794..0000000 --- a/tests/sorts/tests_heap_sort.f90 +++ /dev/null @@ -1,98 +0,0 @@ -!> Test program for the Heap Sort algorithm -!! -!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) -!! in Pull Request: #8 -!! https://github.com/TheAlgorithms/Fortran/pull/8 -!! -!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request -!! addressing bugs/corrections to this file. Thank you! -!! -!! This program provides additional test cases to validate the heap_sort_module. - -program tests_heap_sort - - use heap_sort_module - implicit none - integer, dimension(:), allocatable :: array - - ! Test 1: Repeated elements - print *, "Test 1: Array with repeated elements" - array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) - call run_test(array) - - ! Test 2: Already sorted array - print *, "Test 2: Already sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/1, 2, 3, 4, 5, 6, 7, 8/) - call run_test(array) - - ! Test 3: Reverse sorted array - print *, "Test 3: Reverse sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/8, 7, 6, 5, 4, 3, 2, 1/) - call run_test(array) - - ! Test 4: Array with all negative numbers - print *, "Test 4: Array with all negative numbers" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/-1, -5, -3, -7, -2, -12, -15, -4/) - call run_test(array) - - ! Test 5: Single element array - print *, "Test 5: Single element array" - if (allocated(array)) deallocate (array) - allocate (array(1)) - array = (/42/) - call run_test(array) - - ! Test 6: Array with identical elements - print *, "Test 6: Array with identical elements" - if (allocated(array)) deallocate (array) - allocate (array(5)) - array = (/7, 7, 7, 7, 7/) - call run_test(array) - - ! Test 7: Array with alternating high and low values - print *, "Test 7: Array with alternating high and low values" - if (allocated(array)) deallocate (array) - allocate (array(6)) - array = (/1, 1000, 2, 999, 3, 998/) - call run_test(array) - - ! Test 8: Empty array - print *, "Test 8: Empty array" - if (allocated(array)) deallocate (array) - allocate (array(0)) - call run_test(array) - -contains - - !> Subroutine to run and print the heap sort test - subroutine run_test(array) - integer, dimension(:), intent(inout) :: array - integer :: n, i - - n = size(array) - - ! Print original array - print *, "Original array:" - do i = 1, n - print *, array(i) - end do - - ! Call heap_sort - call heap_sort(array, n) - - ! Print sorted array - print *, "Sorted array:" - do i = 1, n - print *, array(i) - end do - - print *, "" - end subroutine run_test - -end program tests_heap_sort diff --git a/tests/sorts/tests_merge_sort.f90 b/tests/sorts/tests_merge_sort.f90 deleted file mode 100644 index 5da8ad0..0000000 --- a/tests/sorts/tests_merge_sort.f90 +++ /dev/null @@ -1,98 +0,0 @@ -!> Test program for the Merge Sort algorithm -!! -!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) -!! in Pull Request: #7 -!! https://github.com/TheAlgorithms/Fortran/pull/7 -!! -!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request -!! addressing bugs/corrections to this file. Thank you! -!! -!! This program provides additional test cases to validate the merge_sort_module. - -program tests_merge_sort - - use merge_sort_module - implicit none - integer, dimension(:), allocatable :: array - - ! Test 1: Repeated elements - print *, "Test 1: Array with repeated elements" - array = (/4, 2, 7, 3, 1, 4, 9, 5, 10, 9, 2, 1/) - call run_test(array) - - ! Test 2: Already sorted array - print *, "Test 2: Already sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/1, 2, 3, 4, 5, 6, 7, 8/) - call run_test(array) - - ! Test 3: Reverse sorted array - print *, "Test 3: Reverse sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/8, 7, 6, 5, 4, 3, 2, 1/) - call run_test(array) - - ! Test 4: Array with all negative numbers - print *, "Test 4: Array with all negative numbers" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/-11, -55, -43, -70, -2, -1, -15, -9/) - call run_test(array) - - ! Test 5: Single element array - print *, "Test 5: Single element array" - if (allocated(array)) deallocate (array) - allocate (array(1)) - array = (/62/) - call run_test(array) - - ! Test 6: Array with identical elements - print *, "Test 6: Array with identical elements" - if (allocated(array)) deallocate (array) - allocate (array(5)) - array = (/4, 4, 4, 4, 4/) - call run_test(array) - - ! Test 7: Array with alternating high and low values - print *, "Test 7: Array with alternating high and low values" - if (allocated(array)) deallocate (array) - allocate (array(6)) - array = (/10, 2000, 20, 888, 30, 798/) - call run_test(array) - - ! Test 8: Empty array - print *, "Test 8: Empty array" - if (allocated(array)) deallocate (array) - allocate (array(0)) - call run_test(array) - -contains - - !> Subroutine to run and print the merge sort test - subroutine run_test(array) - integer, dimension(:), intent(inout) :: array - integer :: n, i - - n = size(array) - - ! Print original array - print *, "Original array:" - do i = 1, n - print *, array(i) - end do - - ! Call merge_sort - call merge_sort(array, n) - - ! Print sorted array - print *, "Sorted array:" - do i = 1, n - print *, array(i) - end do - - print *, "" - end subroutine run_test - -end program tests_merge_sort diff --git a/tests/sorts/tests_quick_sort.f90 b/tests/sorts/tests_quick_sort.f90 deleted file mode 100644 index a46835f..0000000 --- a/tests/sorts/tests_quick_sort.f90 +++ /dev/null @@ -1,98 +0,0 @@ -!> Test program for the Quick Sort algorithm -!! -!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) -!! in Pull Request: #10 -!! https://github.com/TheAlgorithms/Fortran/pull/10 -!! -!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request -!! addressing bugs/corrections to this file. Thank you! -!! -!! This program provides additional test cases to validate the quick_sort_module. - -program tests_quick_sort - - use quick_sort_module - implicit none - integer, dimension(:), allocatable :: array - - ! Test 1: Repeated elements - print *, "Test 1: Array with repeated elements" - array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) - call run_test(array) - - ! Test 2: Already sorted array - print *, "Test 2: Already sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/1, 2, 3, 4, 5, 6, 7, 8/) - call run_test(array) - - ! Test 3: Reverse sorted array - print *, "Test 3: Reverse sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/8, 7, 6, 5, 4, 3, 2, 1/) - call run_test(array) - - ! Test 4: Array with all negative numbers - print *, "Test 4: Array with all negative numbers" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/-1, -5, -3, -7, -2, -12, -15, -4/) - call run_test(array) - - ! Test 5: Single element array - print *, "Test 5: Single element array" - if (allocated(array)) deallocate (array) - allocate (array(1)) - array = (/42/) - call run_test(array) - - ! Test 6: Array with identical elements - print *, "Test 6: Array with identical elements" - if (allocated(array)) deallocate (array) - allocate (array(5)) - array = (/7, 7, 7, 7, 7/) - call run_test(array) - - ! Test 7: Array with alternating high and low values - print *, "Test 7: Array with alternating high and low values" - if (allocated(array)) deallocate (array) - allocate (array(6)) - array = (/1, 1000, 2, 999, 3, 998/) - call run_test(array) - - ! Test 8: Empty array - print *, "Test 8: Empty array" - if (allocated(array)) deallocate (array) - allocate (array(0)) - call run_test(array) - -contains - - !> Subroutine to run and print the quick sort test - subroutine run_test(array) - integer, dimension(:), intent(inout) :: array - integer :: n, i - - n = size(array) - - ! Print original array - print *, "Original array:" - do i = 1, n - print *, array(i) - end do - - ! Call quick_sort - call quick_sort(array, 1, n) ! (1: low bound , n: high bound) of the array - - ! Print sorted array - print *, "Sorted array:" - do i = 1, n - print *, array(i) - end do - - print *, "" - end subroutine run_test - -end program tests_quick_sort diff --git a/tests/sorts/tests_radix_sort.f90 b/tests/sorts/tests_radix_sort.f90 deleted file mode 100644 index 056fd5c..0000000 --- a/tests/sorts/tests_radix_sort.f90 +++ /dev/null @@ -1,124 +0,0 @@ -!> Test program for the Radix Sort algorithm -!! -!! Created by: Ramy-Badr-Ahmed (https://github.com/Ramy-Badr-Ahmed) -!! in Pull Request: #11 -!! https://github.com/TheAlgorithms/Fortran/pull/11 -!! -!! Please mention me (@Ramy-Badr-Ahmed) in any issue or pull request -!! addressing bugs/corrections to this file. Thank you! -!! -!! This program provides additional test cases to validate the radix_sort_module. -!! The radix (base) parameter affects the internal digit processing for sorting, but the final output is always in decimal form. - -program tests_radix_sort - use radix_sort_module - implicit none - integer, dimension(:), allocatable :: array - integer, parameter :: base10 = 10, base2 = 2, base16 = 16 - - ! Test 1: Base 10 - print *, "Test 1: Radix Sort with base 10" - if (allocated(array)) deallocate (array) - allocate (array(10)) - array = (/170, 45, 75, 90, 802, 24, 2, 66, 15, 40/) - call run_test(array, base10) - - ! Test 2: Base 2 - print *, "Test 2: Radix Sort with base 2" - if (allocated(array)) deallocate (array) - allocate (array(10)) - array = (/10, 13, 9, 14, 2, 5, 15, 6, 8, 1/) ! Binary values as decimal - call run_test(array, base2) - - ! Test 3: Base 16 - print *, "Test 3: Radix Sort with base 16" - if (allocated(array)) deallocate (array) - allocate (array(10)) - array = (/171, 31, 61, 255, 16, 5, 211, 42, 180, 0/) ! Hexadecimal values as decimal - call run_test(array, base16) - - ! Test 4: Repeated elements - print *, "Test 4: Array with repeated elements" - if (allocated(array)) deallocate (array) - allocate (array(12)) - array = (/5, 3, 8, 3, 1, 5, 7, 5, 10, 7, 3, 1/) - call run_test(array, base10) - - ! Test 5: Already sorted array - print *, "Test 5: Already sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/1, 2, 3, 4, 5, 6, 7, 8/) - call run_test(array, base10) - - ! Test 6: Reverse sorted array - print *, "Test 6: Reverse sorted array" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/8, 7, 6, 5, 4, 3, 2, 1/) - call run_test(array, base10) - - ! Test 7: Array with all negative numbers (Note: Radix Sort only handles non-negative integers) - print *, "Test 7: Array with all negative numbers (handled as base 10)" - if (allocated(array)) deallocate (array) - allocate (array(8)) - array = (/-1, -5, -3, -7, -2, -12, -15, -4/) - call run_test(array, base10) - - ! Test 8: Single element array - print *, "Test 8: Single element array" - if (allocated(array)) deallocate (array) - allocate (array(1)) - array = (/42/) - call run_test(array, base10) - - ! Test 9: Array with identical elements - print *, "Test 9: Array with identical elements" - if (allocated(array)) deallocate (array) - allocate (array(5)) - array = (/7, 7, 7, 7, 7/) - call run_test(array, base10) - - ! Test 10: Array with alternating high and low values - print *, "Test 10: Array with alternating high and low values" - if (allocated(array)) deallocate (array) - allocate (array(6)) - array = (/1, 1000, 2, 999, 3, 998/) - call run_test(array, base10) - - ! Test 11: Empty array - print *, "Test 11: Empty array" - if (allocated(array)) deallocate (array) - allocate (array(0)) - call run_test(array, base10) - -contains - - !> Subroutine to run and print the radix sort test - subroutine run_test(array, base) - integer, dimension(:), intent(inout) :: array - integer, intent(in) :: base - integer :: n, i - - n = size(array) - - ! Print original array - print *, "Original array:" - do i = 1, n - print *, array(i) - end do - - ! Call radix_sort - ! The parameters specify the array to sort, its size, and the base for sorting. - call radix_sort(array, n, base) - - ! Print sorted array - print *, "Sorted array:" - do i = 1, n - print *, array(i) - end do - - print *, "" - end subroutine run_test - -end program tests_radix_sort