Added more tests

This commit is contained in:
Benoy Bose 2024-11-28 18:09:56 +05:30
parent ef66ec9ebd
commit 1a80064f9b
3 changed files with 60 additions and 9 deletions

View File

@ -2,10 +2,9 @@ lexer grammar HooLexer;
IDENTIFIER: Letter LetterOrDigit*; IDENTIFIER: Letter LetterOrDigit*;
DECIMAL_LITERAL : '0' | [1-9] [0-9]*; fragment DIGIT: [0-9];
// HEX_LITERAL : '0' [xX] [0-9a-fA-F] ([0-9a-fA-F_]* [0-9a-fA-F])? [lL]?;
// OCT_LITERAL : '0' '_'* [0-7] ([0-7_]* [0-7])? [lL]?; DECIMAL_LITERAL: '0' | ('+' | '-')? [1-9] [0-9]*;
// BINARY_LITERAL : '0' [bB] [01] ([01_]* [01])? [lL]?;
FLOAT_LITERAL: (Digits '.' Digits? | '.' Digits); FLOAT_LITERAL: (Digits '.' Digits? | '.' Digits);

View File

@ -20,7 +20,11 @@ std::any Visitor::visitLiteral(HooParser::LiteralContext *ctx)
auto decimalText = value->getText(); auto decimalText = value->getText();
double decimalValue = std::stoll(decimalText); double decimalValue = std::stoll(decimalText);
llvm::Type *decimalType = llvm::Type::getInt64Ty(*_context); llvm::Type *decimalType = llvm::Type::getInt64Ty(*_context);
llvm::Constant *decimalConstant = llvm::ConstantInt::get(decimalType, decimalValue, true); llvm::Constant *decimalConstant = llvm::ConstantInt::getSigned(decimalType, decimalValue);
#ifdef DEBUG
auto constantValue = llvm::dyn_cast<llvm::ConstantInt>(decimalConstant)->getValue().getSExtValue();
assert(constantValue == decimalValue);
#endif
return std::any{Node(NODE_LITERAL, DATATYPE_INTEGER, decimalConstant)}; return std::any{Node(NODE_LITERAL, DATATYPE_INTEGER, decimalConstant)};
} }

View File

@ -1,15 +1,63 @@
#include "Compiler.hpp" #include "Compiler.hpp"
#include "Node.hpp" #include "Node.hpp"
#include "llvm/IR/Constants.h"
#include <gtest/gtest.h> #include <gtest/gtest.h>
TEST(IntegerTest, Literal) TEST(IntegerTest, LiteralOne)
{ {
auto compiler = new Compiler("1;", "main"); auto compiler = std::make_unique<Compiler>("1;", "main");
auto result = compiler->compile(); auto result = compiler->compile();
auto integer = std::any_cast<Node>(result); auto integer = std::any_cast<Node>(result);
ASSERT_EQ(integer.getNodeType(), NODE_LITERAL); ASSERT_EQ(integer.getNodeType(), NODE_LITERAL);
ASSERT_EQ(integer.getDataType(), DATATYPE_INTEGER); ASSERT_EQ(integer.getDataType(), DATATYPE_INTEGER);
ASSERT_EQ(integer.getValue(), llvm::ConstantInt::get(llvm::Type::getInt64Ty(*compiler->getContext()), 1, true)); auto value = integer.getValue();
delete compiler; auto expected_value = llvm::ConstantInt::get(llvm::Type::getInt64Ty(*compiler->getContext()), 1, true);
ASSERT_EQ(value, expected_value);
}
TEST(IntegerTest, LiteralNumberPositive)
{
auto compiler = std::make_unique<Compiler>("67890;", "main");
auto result = compiler->compile();
auto integer = std::any_cast<Node>(result);
ASSERT_EQ(integer.getNodeType(), NODE_LITERAL);
ASSERT_EQ(integer.getDataType(), DATATYPE_INTEGER);
auto value = integer.getValue();
auto expected_value = llvm::ConstantInt::get(llvm::Type::getInt64Ty(*compiler->getContext()), 67890, true);
ASSERT_EQ(value, expected_value);
}
TEST(IntegerTest, LiteralNumberPositiveWithPlus)
{
auto compiler = std::make_unique<Compiler>("+67890;", "main");
auto result = compiler->compile();
auto integer = std::any_cast<Node>(result);
ASSERT_EQ(integer.getNodeType(), NODE_LITERAL);
ASSERT_EQ(integer.getDataType(), DATATYPE_INTEGER);
auto value = integer.getValue();
auto expected_value = llvm::ConstantInt::get(llvm::Type::getInt64Ty(*compiler->getContext()), 67890, true);
ASSERT_EQ(value, expected_value);
}
TEST(IntegerTest, LiteralNumberNegative)
{
auto compiler = std::make_unique<Compiler>("-67890;", "main");
auto result = compiler->compile();
auto integer = std::any_cast<Node>(result);
ASSERT_EQ(integer.getNodeType(), NODE_LITERAL);
ASSERT_EQ(integer.getDataType(), DATATYPE_INTEGER);
auto value = integer.getValue();
auto expected_value = llvm::ConstantInt::get(
llvm::Type::getInt64Ty(*compiler->getContext()), -67890, true);
auto value_constant = llvm::dyn_cast<llvm::ConstantInt>(value);
auto expected_value_constant = llvm::dyn_cast<llvm::ConstantInt>(expected_value);
ASSERT_NE(value_constant, nullptr);
ASSERT_NE(expected_value_constant, nullptr);
ASSERT_EQ(value_constant->getValue(), expected_value_constant->getValue());
ASSERT_EQ(value, expected_value);
} }