Create read module
This commit is contained in:
@@ -16,6 +16,7 @@ add_test_suites(
|
||||
parse_tests.c
|
||||
prim_tests.c
|
||||
print_tests.c
|
||||
read_tests.c
|
||||
store_tests.c
|
||||
token_tests.c
|
||||
)
|
||||
|
||||
98
tests/read_tests.c
Normal file
98
tests/read_tests.c
Normal file
@@ -0,0 +1,98 @@
|
||||
#include "memory_stream.h"
|
||||
#include "read.h"
|
||||
#include "unity.h"
|
||||
|
||||
#include <string.h>
|
||||
|
||||
#define CAR(expr) (expr->pair.car)
|
||||
#define CDR(expr) (expr->pair.cdr)
|
||||
#define CADR(expr) CAR(CDR(expr))
|
||||
#define CDDR(expr) CDR(CDR(expr))
|
||||
#define CADDR(expr) CAR(CDDR(expr))
|
||||
#define CDDDR(expr) CDR(CDDR(expr))
|
||||
#define CAADDR(expr) CAR(CADDR(expr))
|
||||
#define CDADDR(expr) CDR(CADDR(expr))
|
||||
#define CADADDR(expr) CAR(CDADDR(expr))
|
||||
#define CDDADDR(expr) CDR(CDADDR(expr))
|
||||
#define CADDADDR(expr) CAR(CDDADDR(expr))
|
||||
#define CDDDADDR(expr) CDR(CDDADDR(expr))
|
||||
|
||||
static am_t am;
|
||||
|
||||
void setUp(void)
|
||||
{
|
||||
am_init(&am);
|
||||
}
|
||||
|
||||
void tearDown(void)
|
||||
{
|
||||
}
|
||||
|
||||
static void test_nested_expression(void)
|
||||
{
|
||||
const char *input = "(+ 1 (* 2 3))";
|
||||
memory_stream_t stream;
|
||||
memory_stream_init(&stream, (const uint8_t *)input, strlen(input));
|
||||
|
||||
read(&am, (stream_t *)&stream);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(am.expr);
|
||||
TEST_ASSERT_FALSE(am.expr->is_atom);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CAR(am.expr));
|
||||
TEST_ASSERT_TRUE(CAR(am.expr)->is_atom);
|
||||
TEST_ASSERT_EQUAL(ATOM_TYPE_SYMBOL, CAR(am.expr)->atom.type);
|
||||
TEST_ASSERT_EQUAL(1, CAR(am.expr)->atom.symbol.len);
|
||||
TEST_ASSERT_EQUAL_MEMORY("+", CAR(am.expr)->atom.symbol.buf, 1);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CDR(am.expr));
|
||||
TEST_ASSERT_FALSE(CDR(am.expr)->is_atom);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CADR(am.expr));
|
||||
TEST_ASSERT_TRUE(CADR(am.expr)->is_atom);
|
||||
TEST_ASSERT_EQUAL(ATOM_TYPE_INTEGER, CADR(am.expr)->atom.type);
|
||||
TEST_ASSERT_EQUAL(1, CADR(am.expr)->atom.integer);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CDDR(am.expr));
|
||||
TEST_ASSERT_FALSE(CDDR(am.expr)->is_atom);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CADDR(am.expr));
|
||||
TEST_ASSERT_FALSE(CADDR(am.expr)->is_atom);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CAADDR(am.expr));
|
||||
TEST_ASSERT_TRUE(CAADDR(am.expr)->is_atom);
|
||||
TEST_ASSERT_EQUAL(ATOM_TYPE_SYMBOL, CAADDR(am.expr)->atom.type);
|
||||
TEST_ASSERT_EQUAL(1, CAADDR(am.expr)->atom.symbol.len);
|
||||
TEST_ASSERT_EQUAL_MEMORY("*", CAADDR(am.expr)->atom.symbol.buf, 1);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CDADDR(am.expr));
|
||||
TEST_ASSERT_FALSE(CDADDR(am.expr)->is_atom);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CADADDR(am.expr));
|
||||
TEST_ASSERT_TRUE(CADADDR(am.expr)->is_atom);
|
||||
TEST_ASSERT_EQUAL(ATOM_TYPE_INTEGER, CADADDR(am.expr)->atom.type);
|
||||
TEST_ASSERT_EQUAL(2, CADADDR(am.expr)->atom.integer);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CDDADDR(am.expr));
|
||||
TEST_ASSERT_FALSE(CDDADDR(am.expr)->is_atom);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CADDADDR(am.expr));
|
||||
TEST_ASSERT_TRUE(CADDADDR(am.expr)->is_atom);
|
||||
TEST_ASSERT_EQUAL(ATOM_TYPE_INTEGER, CADDADDR(am.expr)->atom.type);
|
||||
TEST_ASSERT_EQUAL(3, CADDADDR(am.expr)->atom.integer);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CDDDADDR(am.expr));
|
||||
TEST_ASSERT_TRUE(CDDDADDR(am.expr)->is_atom);
|
||||
TEST_ASSERT_EQUAL(ATOM_TYPE_EMPTY_LIST, CDDDADDR(am.expr)->atom.type);
|
||||
|
||||
TEST_ASSERT_NOT_NULL(CDDDR(am.expr));
|
||||
TEST_ASSERT_TRUE(CDDDR(am.expr)->is_atom);
|
||||
TEST_ASSERT_EQUAL(ATOM_TYPE_EMPTY_LIST, CDDDR(am.expr)->atom.type);
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
UNITY_BEGIN();
|
||||
RUN_TEST(test_nested_expression);
|
||||
return UNITY_END();
|
||||
}
|
||||
Reference in New Issue
Block a user