This commit is contained in:
@@ -13,6 +13,8 @@ steps:
|
||||
- name: test
|
||||
image: ubuntu
|
||||
commands:
|
||||
# TODO: Probably make actual tests at some point
|
||||
# Automated tests, this should not fail
|
||||
- ./test
|
||||
# Manual test, you can see the output of this in woodpecker
|
||||
- echo "(print 42)" | ./build/main
|
||||
# TODO: add publish step, when we're at a working state.
|
@@ -1,10 +1,30 @@
|
||||
cmake_minimum_required(VERSION 3.16)
|
||||
project(lispy_stuff)
|
||||
|
||||
# we'll use catch2 as testing library.
|
||||
include(FetchContent)
|
||||
FetchContent_Declare(
|
||||
Catch2
|
||||
GIT_REPOSITORY https://github.com/catchorg/Catch2.git
|
||||
GIT_TAG v3.8.1
|
||||
)
|
||||
FetchContent_MakeAvailable(Catch2)
|
||||
list(APPEND CMAKE_MODULE_PATH ${catch2_SOURCE_DIR}/extras)
|
||||
include(Catch)
|
||||
|
||||
set(HEADER_FILES src/include/lex.hpp)
|
||||
set(SOURCE_FILES src/main.cpp src/lex.cpp)
|
||||
set(SOURCE_FILES src/lex.cpp)
|
||||
|
||||
# we're not actually shipping a library yet,
|
||||
# this is so we don't have to compile twice for main and tests.
|
||||
add_library(libmash STATIC ${SOURCE_FILES} ${HEADER_FILES})
|
||||
target_include_directories(libmash PUBLIC src/include/)
|
||||
|
||||
add_executable(main ${SOURCE_FILES} ${HEADER_FILES})
|
||||
# Main target
|
||||
add_executable(main src/main.cpp)
|
||||
target_link_libraries(main libmash)
|
||||
|
||||
# tests
|
||||
add_executable(test src/tests/test.cpp)
|
||||
target_link_libraries(test PRIVATE libmash Catch2::Catch2WithMain)
|
||||
|
||||
target_include_directories(main PRIVATE src/include/)
|
21
src/tests/test.cpp
Normal file
21
src/tests/test.cpp
Normal file
@@ -0,0 +1,21 @@
|
||||
#include <catch2/catch_test_macros.hpp>
|
||||
#include <lex.hpp>
|
||||
using namespace std;
|
||||
|
||||
TEST_CASE("Lexer lexes doubles correctly", "[Lexer]") {
|
||||
|
||||
SECTION("double and negative syntax") {
|
||||
Lexer l("(1.0 0.1 -.1 -1. . - -. .-)");
|
||||
REQUIRE(l.next() == Token({OpenParen}));
|
||||
REQUIRE(l.next() == Token({Double, 1.0}));
|
||||
REQUIRE(l.next() == Token({Double, 0.1}));
|
||||
REQUIRE(l.next() == Token({Double, -0.1}));
|
||||
REQUIRE(l.next() == Token({Double, -1.0}));
|
||||
REQUIRE(l.next() == Token({Symbol, "."}));
|
||||
REQUIRE(l.next() == Token({Symbol, "-"}));
|
||||
REQUIRE(l.next() == Token({Symbol, "-."}));
|
||||
REQUIRE(l.next() == Token({Symbol, ".-"}));
|
||||
REQUIRE(l.next() == Token({CloseParen}));
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user