audio/test/test_int8_8.cpp

235 lines
6.0 KiB
C++
Raw Normal View History

/** @file
* @author Edouard DUPIN
* @copyright 2015, Edouard DUPIN, all right reserved
* @license MPL v2.0 (see license file)
*/
2016-10-02 20:37:21 +02:00
#include <test-debug/debug.hpp>
2017-09-07 23:38:26 +02:00
#include <etest/etest.hpp>
2016-10-02 20:37:21 +02:00
#include <audio/types.hpp>
2015-04-09 23:20:58 +02:00
TEST(TestInt8_8, basicConstructorBase) {
audio::int8_8_t typeBase(16);
2015-04-09 23:20:58 +02:00
EXPECT_EQ(typeBase.get(), 16);
}
TEST(TestInt8_8, basicConstructorSetOne) {
audio::int8_8_t typeBase(1, 0);
2017-11-07 13:38:04 +01:00
EXPECT_EQ(typeBase.get(), ((1<<7)-1));
2015-04-09 23:20:58 +02:00
}
TEST(TestInt8_8, basicConstructorSetLessOne) {
audio::int8_8_t typeBase(-1, 0);
2017-11-07 13:38:04 +01:00
EXPECT_EQ(typeBase.get(), (-(1<<7)));
2015-04-09 23:20:58 +02:00
}
TEST(TestInt8_8, basicOperatorEqual) {
audio::int8_8_t typeBase;
typeBase = 35;
EXPECT_EQ(typeBase.get(), 35);
}
TEST(TestInt8_8, basicOperatorPlus) {
audio::int8_8_t typeBase(35);
typeBase += 35;
EXPECT_EQ(typeBase.get(), 70);
}
TEST(TestInt8_8, basicOperatorMinus) {
audio::int8_8_t typeBase(55);
typeBase -= 35;
EXPECT_EQ(typeBase.get(), 20);
typeBase -= 35;
EXPECT_EQ(typeBase.get(), -15);
}
TEST(TestInt8_8, basicOperatorMultiplication) {
audio::int8_8_t typeBase(-1, 0);
typeBase *= 35;
EXPECT_EQ(typeBase.get(), -35);
typeBase = audio::int8_8_t(5, 3);
typeBase *= audio::int8_8_t(3, 3);
EXPECT_EQ(typeBase.get(), audio::int8_8_t(15, 6).get());
}
TEST(TestInt8_8, basicOperatorCompareEquality) {
audio::int8_8_t typeBase1(-12, 5);
audio::int8_8_t typeBase2(-12, 5);
bool result = typeBase1 == typeBase2;
EXPECT_EQ(result, true);
typeBase2.set(12, 5);
result = typeBase1 == typeBase2;
EXPECT_EQ(result, false);
}
TEST(TestInt8_8, basicOperatorCompareInEquality) {
audio::int8_8_t typeBase1(-12, 5);
audio::int8_8_t typeBase2(-12, 5);
bool result = typeBase1 != typeBase2;
EXPECT_EQ(result, false);
typeBase2.set(12, 5);
result = typeBase1 != typeBase2;
EXPECT_EQ(result, true);
}
TEST(TestInt8_8, basicOperatorCompareMinor) {
audio::int8_8_t typeBase1(-12, 5);
audio::int8_8_t typeBase2(-12, 5);
bool result = typeBase1 < typeBase2;
EXPECT_EQ(result, false);
typeBase2.set(-15, 5);
result = typeBase1 < typeBase2;
EXPECT_EQ(result, false);
typeBase2.set(12, 5);
result = typeBase1 < typeBase2;
EXPECT_EQ(result, true);
}
TEST(TestInt8_8, basicOperatorCompareEqualityMinor) {
audio::int8_8_t typeBase1(-12, 5);
audio::int8_8_t typeBase2(-12, 5);
bool result = typeBase1 <= typeBase2;
EXPECT_EQ(result, true);
typeBase2.set(-15, 5);
result = typeBase1 <= typeBase2;
EXPECT_EQ(result, false);
typeBase2.set(12, 5);
result = typeBase1 <= typeBase2;
EXPECT_EQ(result, true);
}
TEST(TestInt8_8, basicOperatorCompareMajor) {
audio::int8_8_t typeBase1(-12, 5);
audio::int8_8_t typeBase2(-12, 5);
bool result = typeBase1 > typeBase2;
EXPECT_EQ(result, false);
typeBase2.set(-15, 5);
result = typeBase1 > typeBase2;
EXPECT_EQ(result, true);
typeBase2.set(12, 5);
result = typeBase1 > typeBase2;
EXPECT_EQ(result, false);
}
TEST(TestInt8_8, basicOperatorCompareEqualityMajor) {
audio::int8_8_t typeBase1(-12, 5);
audio::int8_8_t typeBase2(-12, 5);
bool result = typeBase1 >= typeBase2;
EXPECT_EQ(result, true);
typeBase2.set(-15, 5);
result = typeBase1 >= typeBase2;
EXPECT_EQ(result, true);
typeBase2.set(12, 5);
result = typeBase1 >= typeBase2;
EXPECT_EQ(result, false);
}
TEST(TestInt8_8, basicOperatorLiteralPlus) {
audio::int8_8_t out;
out = audio::int8_8_t(-13, 5) + audio::int8_8_t(12, 5);
EXPECT_EQ(out.get(), audio::int8_8_t(-1,5).get());
}
TEST(TestInt8_8, basicOperatorLiteralMinus) {
audio::int8_8_t out;
out = audio::int8_8_t(-13, 5) - audio::int8_8_t(12, 5);
EXPECT_EQ(out.get(), audio::int8_8_t(-25,5).get());
}
TEST(TestInt8_8, basicOperatorLiteralMultiplication) {
audio::int8_8_t out;
out = audio::int8_8_t(-5, 3) * audio::int8_8_t(3, 3);
EXPECT_EQ(out.get(), audio::int8_8_t(-15,6).get());
}
TEST(TestInt8_8, basicOperatorDividing) {
audio::int8_8_t out(-15, 5);
out /= audio::int8_8_t(3, 2);
EXPECT_EQ(out.get(), audio::int8_8_t(-5,3).get());
}
TEST(TestInt8_8, basicOperatorLiteralDividing) {
audio::int8_8_t out;
out = audio::int8_8_t(-15, 5) / audio::int8_8_t(3, 2);
EXPECT_EQ(out.get(), audio::int8_8_t(-5,3).get());
}
/*
TEST(TestInt8_8, basicOperatorIncrementPost) {
audio::int8_8_t out(10, 0);
out++;
EXPECT_EQ(out.get(), audio::int8_8_t(11, 0).get());
}
TEST(TestInt8_8, basicOperatorIncrementPre) {
audio::int8_8_t out(10, 0);
++out;
EXPECT_EQ(out.get(), audio::int8_8_t(11, 0).get());
}
TEST(TestInt8_8, basicOperatorDecrementPost) {
audio::int8_8_t out(10, 0);
out--;
EXPECT_EQ(out.get(), audio::int8_8_t(9, 0).get());
}
TEST(TestInt8_8, basicOperatorDecrementPre) {
audio::int8_8_t out(10, 0);
--out;
EXPECT_EQ(out.get(), audio::int8_8_t(9, 0).get());
}
*/
#define RESULT_VALUE (40)
TEST(TestInt8_8, basicConstructorInt8_8) {
audio::int8_8_t out(audio::int8_8_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt8_16) {
audio::int8_8_t out(audio::int8_16_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt16_16) {
audio::int8_8_t out(audio::int16_16_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt24_24) {
audio::int8_8_t out(audio::int24_24_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt24_32) {
audio::int8_8_t out(audio::int24_32_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt16_32) {
audio::int8_8_t out(audio::int16_32_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt32_32) {
audio::int8_8_t out(audio::int32_32_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt32_64) {
audio::int8_8_t out(audio::int32_64_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorInt64_64) {
audio::int8_8_t out(audio::int64_64_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorFloat) {
audio::int8_8_t out(audio::float_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}
TEST(TestInt8_8, basicConstructorDouble) {
audio::int8_8_t out(audio::double_t(5,4));
EXPECT_EQ(RESULT_VALUE, out.get());
}