diff options
author | Lars Muldjord <muldjordlars@gmail.com> | 2017-03-23 19:22:38 +0100 |
---|---|---|
committer | Lars Muldjord <muldjordlars@gmail.com> | 2017-03-23 19:22:38 +0100 |
commit | 889070f5c84f67cb52a5038fe93aca6234bbc360 (patch) | |
tree | 5c9ccdac1c8e7c13e501c89b2fbbaffa04340391 /test | |
parent | 83745f8bf86d22936c5c2c7becc86885119f5d29 (diff) | |
parent | 494e7218597a6cd94902b3ae6f827e74b41c00b0 (diff) |
Merge branch 'master' of http://git.drumgizmo.org/drumgizmo
Diffstat (limited to 'test')
-rw-r--r-- | test/Makefile.am | 12 | ||||
-rw-r--r-- | test/bytesizeparsertest.cc | 127 |
2 files changed, 137 insertions, 2 deletions
diff --git a/test/Makefile.am b/test/Makefile.am index 12d4713..58d7f1b 100644 --- a/test/Makefile.am +++ b/test/Makefile.am @@ -6,7 +6,7 @@ if ENABLE_TESTS TESTS = resource enginetest paintertest resampler configfile audiocache \ audiocachefile audiocacheidmanager audiocacheeventhandler \ memchecker randomtest atomictest syncedsettingstest imagecachetest \ - semaphoretest drumkitcreatortest + semaphoretest drumkitcreatortest bytesizeparsertest if ENABLE_LV2 TESTS += lv2 @@ -189,7 +189,7 @@ semaphoretest_SOURCES = \ semaphoretest.cc \ test.cc -drumkitcreatortest_CXXFLAGS = -DOUTPUT=\"drumkitcreatortest\" $(CPPUNIT_CFLAGS) +drumkitcreatortest_CXXFLAGS = -DOUTPUT=\"drumkitcreatortest\" $(CPPUNIT_CFLAGS) \ -I$(top_srcdir)/src \ -I$(top_srcdir)/hugin -DDISABLE_HUGIN drumkitcreatortest_CFLAGS = -DDISABLE_HUGIN @@ -200,4 +200,12 @@ drumkitcreatortest_SOURCES = \ drumkit_creator.cc \ drumkitcreatortest.cc +bytesizeparsertest_CXXFLAGS = -DOUTPUT=\"bytesizeparsertest\" $(CPPUNIT_CFLAGS) \ + -I$(top_srcdir)/src +bytesizeparsertest_LDFLAGS = $(CPPUNIT_LIBS) +bytesizeparsertest_SOURCES = \ + $(top_srcdir)/src/bytesizeparser.cc \ + bytesizeparsertest.cc \ + test.cc + endif diff --git a/test/bytesizeparsertest.cc b/test/bytesizeparsertest.cc new file mode 100644 index 0000000..e4776fe --- /dev/null +++ b/test/bytesizeparsertest.cc @@ -0,0 +1,127 @@ +/* -*- Mode: c++ -*- */ +/*************************************************************************** + * bytesizeparsertest.cc + * + * Sun Mar 05 11:44:23 CET 2017 + * Copyright 2017 Goran Mekić + * meka@tilda.center + ****************************************************************************/ + +/* + * This file is part of DrumGizmo. + * + * DrumGizmo is free software; you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * DrumGizmo is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with DrumGizmo; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ +#include <cppunit/extensions/HelperMacros.h> + +#include "bytesizeparser.h" + + +class ByteSizeParserTest + : public CppUnit::TestFixture +{ + CPPUNIT_TEST_SUITE(ByteSizeParserTest); + CPPUNIT_TEST(suffixTest); + CPPUNIT_TEST(falseSuffixTest); + CPPUNIT_TEST(falseNumberTest); + CPPUNIT_TEST(tooBigNumberTest); + CPPUNIT_TEST_SUITE_END(); + +public: + void setUp() {} + + void tearDown() {} + + void suffixTest() + { + std::size_t computed_size, expected_size; + std::size_t kilo = 1024, mega = kilo * 1024, giga = mega * 1024; + computed_size = byteSizeParser("3"); + expected_size = 3; + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3k"); + expected_size = 3 * kilo; + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3M"); + expected_size = 3 * mega; + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3G"); + expected_size = 3 * giga; + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + } + + void falseSuffixTest() + { + std::size_t computed_size, expected_size = 0; + computed_size = byteSizeParser("3K"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3m"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3g"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3ddDD"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + } + + void falseNumberTest() + { + std::size_t computed_size, expected_size = 0; + computed_size = byteSizeParser("K3k"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("-3"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("-3k"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("-3M"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("-3G"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3-"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3-k"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("k-3"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser("3-1"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + + computed_size = byteSizeParser(" -3"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + } + + void tooBigNumberTest() + { + std::size_t computed_size, expected_size = 0; + computed_size = byteSizeParser("999999999999999999999999999999999999G"); + CPPUNIT_ASSERT_EQUAL(expected_size, computed_size); + } +}; + +// Registers the fixture into the 'registry' +CPPUNIT_TEST_SUITE_REGISTRATION(ByteSizeParserTest); |