Daniel Carvalho has uploaded this change for review. (
https://gem5-review.googlesource.com/c/public/gem5/+/38776 )
Change subject: sim: Fix ParseParam<char> and add Parse/ShowParam tests
......................................................................
sim: Fix ParseParam<char> and add Parse/ShowParam tests
Add a GTest for the functionality of sim/serialize_handlers.hh.
Since there is a specialization for chars in showParam, there
must be a corresponding specialization for parseParam; otherwise,
the converting from one to the other and back will result in a
value that does not match the original value.
Change-Id: I1128c7adb12a3c7d091e26db13733ba45e1e61fe
Signed-off-by: Daniel R. Carvalho <oda...@yahoo.com.br>
---
M src/sim/SConscript
M src/sim/serialize_handlers.hh
A src/sim/serialize_handlers.test.cc
3 files changed, 433 insertions(+), 0 deletions(-)
diff --git a/src/sim/SConscript b/src/sim/SConscript
index 5436f78..5a2169f 100644
--- a/src/sim/SConscript
+++ b/src/sim/SConscript
@@ -87,6 +87,7 @@
GTest('byteswap.test', 'byteswap.test.cc', '../base/types.cc')
GTest('guest_abi.test', 'guest_abi.test.cc')
GTest('proxy_ptr.test', 'proxy_ptr.test.cc')
+GTest('serialize_handlers.test', 'serialize_handlers.test.cc')
if env['TARGET_ISA'] != 'null':
SimObject('InstTracer.py')
diff --git a/src/sim/serialize_handlers.hh b/src/sim/serialize_handlers.hh
index 5e5c3ff..ebd2c49 100644
--- a/src/sim/serialize_handlers.hh
+++ b/src/sim/serialize_handlers.hh
@@ -96,6 +96,24 @@
};
template <>
+struct ParseParam<char>
+{
+ static bool
+ parse(const std::string &s, char &value)
+ {
+ // In its ShowParam counterpart, characters are always printed as
+ // values, not the characters they encode. Match that behavior by
+ // accepting strings containing the integer representation of the
+ // ascii values, not the characters themselves. For example, "70",
+ // generates the character 'F' (int('F')=70).
+ int8_t aux;
+ const bool success = to_number(s, aux);
+ value = (char)aux;
+ return success;
+ }
+};
+
+template <>
struct ParseParam<std::string>
{
static bool
diff --git a/src/sim/serialize_handlers.test.cc
b/src/sim/serialize_handlers.test.cc
new file mode 100644
index 0000000..2ea790e
--- /dev/null
+++ b/src/sim/serialize_handlers.test.cc
@@ -0,0 +1,414 @@
+/*
+ * Copyright 2020 Daniel R. Carvalho
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met: redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer;
+ * redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution;
+ * neither the name of the copyright holders nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <gtest/gtest.h>
+
+#include <cstdint>
+#include <string>
+
+#include "sim/serialize_handlers.hh"
+
+TEST(SerializeTest, ParseParamInt8)
+{
+ ParseParam<int8_t> parser;
+ int8_t value(0);
+
+ // Zero
+ EXPECT_TRUE(parser.parse("0", value));
+ EXPECT_EQ(0, value);
+
+ // Booleans
+ EXPECT_FALSE(parser.parse("true", value));
+ EXPECT_FALSE(parser.parse("false", value));
+
+ // 8-bit values
+ EXPECT_FALSE(parser.parse("255", value));
+ EXPECT_TRUE(parser.parse("-128", value));
+ EXPECT_EQ(-128, value);
+
+ // 16-bit values
+ EXPECT_FALSE(parser.parse("1000", value));
+ EXPECT_FALSE(parser.parse("-1000", value));
+
+ // 32-bit values
+ EXPECT_FALSE(parser.parse("2147483648", value));
+ EXPECT_FALSE(parser.parse("-1073741824", value));
+
+ // Doubles (scientific numbers should not be converted to integers
+ // correctly)
+ EXPECT_FALSE(parser.parse("123456.789", value));
+ EXPECT_FALSE(parser.parse("-123456.789", value));
+ EXPECT_TRUE(parser.parse("9.87654e+06", value));
+ EXPECT_EQ(9, value);
+
+ // Characters
+ EXPECT_FALSE(parser.parse("E", value));
+ EXPECT_FALSE(parser.parse("a", value));
+
+ // Strings
+ EXPECT_FALSE(parser.parse("Test", value));
+}
+
+TEST(SerializeTest, ParseParamUint32)
+{
+ ParseParam<uint32_t> parser;
+ uint32_t value(0);
+
+ // Zero
+ EXPECT_TRUE(parser.parse("0", value));
+ EXPECT_EQ(0, value);
+
+ // Booleans
+ EXPECT_FALSE(parser.parse("true", value));
+ EXPECT_FALSE(parser.parse("false", value));
+
+ // 8-bit values
+ EXPECT_TRUE(parser.parse("255", value));
+ EXPECT_EQ(255, value);
+ EXPECT_FALSE(parser.parse("-128", value));
+
+ // 16-bit values
+ EXPECT_TRUE(parser.parse("1000", value));
+ EXPECT_EQ(1000, value);
+ EXPECT_FALSE(parser.parse("-1000", value));
+
+ // 32-bit values
+ EXPECT_TRUE(parser.parse("2147483648", value));
+ EXPECT_EQ(2147483648, value);
+ EXPECT_FALSE(parser.parse("-1073741824", value));
+
+ // Doubles (scientific numbers should not be converted to integers
+ // correctly)
+ EXPECT_TRUE(parser.parse("123456.789", value));
+ EXPECT_EQ(123456, value);
+ EXPECT_FALSE(parser.parse("-123456.789", value));
+ EXPECT_TRUE(parser.parse("9.87654e+06", value));
+ EXPECT_EQ(9, value);
+
+ // Characters
+ EXPECT_FALSE(parser.parse("E", value));
+ EXPECT_FALSE(parser.parse("a", value));
+
+ // Strings
+ EXPECT_FALSE(parser.parse("Test", value));
+}
+
+TEST(SerializeTest, ParseParamDouble)
+{
+ ParseParam<double> parser;
+ double value(0.0);
+
+ // Zero
+ EXPECT_TRUE(parser.parse("0", value));
+ EXPECT_EQ(0.0, value);
+
+ // Booleans
+ EXPECT_FALSE(parser.parse("true", value));
+ EXPECT_FALSE(parser.parse("false", value));
+
+ // 8-bit values
+ EXPECT_TRUE(parser.parse("255", value));
+ EXPECT_EQ(255.0, value);
+ EXPECT_TRUE(parser.parse("-128", value));
+ EXPECT_EQ(-128.0, value);
+
+ // 16-bit values
+ EXPECT_TRUE(parser.parse("1000", value));
+ EXPECT_EQ(1000.0, value);
+ EXPECT_TRUE(parser.parse("-1000", value));
+ EXPECT_EQ(-1000.0, value);
+
+ // 32-bit values
+ EXPECT_TRUE(parser.parse("2147483648", value));
+ EXPECT_EQ(2147483648.0, value);
+ EXPECT_TRUE(parser.parse("-1073741824", value));
+ EXPECT_EQ(-1073741824.0, value);
+
+ // Doubles
+ EXPECT_TRUE(parser.parse("123456.789", value));
+ EXPECT_EQ(123456.789, value);
+ EXPECT_TRUE(parser.parse("-123456.789", value));
+ EXPECT_EQ(-123456.789, value);
+ EXPECT_TRUE(parser.parse("9.87654e+06", value));
+ EXPECT_EQ(9.87654e+06, value);
+
+ // Characters
+ EXPECT_FALSE(parser.parse("E", value));
+ EXPECT_FALSE(parser.parse("a", value));
+
+ // Strings
+ EXPECT_FALSE(parser.parse("Test", value));
+}
+
+TEST(SerializeTest, ParseParamBool)
+{
+ ParseParam<bool> parser;
+ bool value(false);
+
+ // Zero
+ EXPECT_FALSE(parser.parse("0", value));
+
+ // Booleans
+ EXPECT_TRUE(parser.parse("true", value));
+ EXPECT_EQ(true, value);
+ EXPECT_TRUE(parser.parse("false", value));
+ EXPECT_EQ(false, value);
+
+ // 8-bit values
+ EXPECT_FALSE(parser.parse("255", value));
+ EXPECT_FALSE(parser.parse("-128", value));
+
+ // 16-bit values
+ EXPECT_FALSE(parser.parse("1000", value));
+ EXPECT_FALSE(parser.parse("-1000", value));
+
+ // 32-bit values
+ EXPECT_FALSE(parser.parse("2147483648", value));
+ EXPECT_FALSE(parser.parse("-1073741824", value));
+
+ // Doubles
+ EXPECT_FALSE(parser.parse("123456.789", value));
+ EXPECT_FALSE(parser.parse("-123456.789", value));
+ EXPECT_FALSE(parser.parse("9.87654e+06", value));
+
+ // Characters
+ EXPECT_FALSE(parser.parse("E", value));
+ EXPECT_FALSE(parser.parse("a", value));
+
+ // Strings
+ EXPECT_FALSE(parser.parse("Test", value));
+}
+
+/** Characters are parsed as integers. */
+TEST(SerializeTest, ParseParamChar)
+{
+ ParseParam<char> parser;
+ char value;
+
+ // Zero
+ EXPECT_TRUE(parser.parse("48", value));
+ EXPECT_EQ('0', value);
+
+ // Booleans
+ EXPECT_FALSE(parser.parse("true", value));
+ EXPECT_FALSE(parser.parse("false", value));
+
+ // 8-bit values
+ EXPECT_FALSE(parser.parse("255", value));
+ EXPECT_TRUE(parser.parse("-128", value));
+ EXPECT_EQ(char(-128), value);
+
+ // 16-bit values
+ EXPECT_FALSE(parser.parse("1000", value));
+ EXPECT_FALSE(parser.parse("-1000", value));
+
+ // 32-bit values
+ EXPECT_FALSE(parser.parse("2147483648", value));
+ EXPECT_FALSE(parser.parse("-1073741824", value));
+
+ // Doubles
+ EXPECT_FALSE(parser.parse("123456.789", value));
+ EXPECT_FALSE(parser.parse("-123456.789", value));
+ EXPECT_TRUE(parser.parse("9.87654e+06", value));
+ EXPECT_EQ(char(9), value);
+
+ // Characters
+ EXPECT_TRUE(parser.parse("69", value));
+ EXPECT_EQ('E', value);
+ EXPECT_TRUE(parser.parse("97", value));
+ EXPECT_EQ('a', value);
+
+ // Strings
+ EXPECT_FALSE(parser.parse("Test", value));
+}
+
+TEST(SerializeTest, ParseParamString)
+{
+ ParseParam<std::string> parser;
+ std::string value("");
+
+ // Zero
+ EXPECT_TRUE(parser.parse("0", value));
+ EXPECT_EQ("0", value);
+
+ // Booleans
+ EXPECT_TRUE(parser.parse("true", value));
+ EXPECT_EQ("true", value);
+ EXPECT_TRUE(parser.parse("false", value));
+ EXPECT_EQ("false", value);
+
+ // 8-bit values
+ EXPECT_TRUE(parser.parse("255", value));
+ EXPECT_EQ("255", value);
+ EXPECT_TRUE(parser.parse("-128", value));
+ EXPECT_EQ("-128", value);
+
+ // 16-bit values
+ EXPECT_TRUE(parser.parse("1000", value));
+ EXPECT_EQ("1000", value);
+ EXPECT_TRUE(parser.parse("-1000", value));
+ EXPECT_EQ("-1000", value);
+
+ // 32-bit values
+ EXPECT_TRUE(parser.parse("2147483648", value));
+ EXPECT_EQ("2147483648", value);
+ EXPECT_TRUE(parser.parse("-1073741824", value));
+ EXPECT_EQ("-1073741824", value);
+
+ // Doubles
+ EXPECT_TRUE(parser.parse("123456.789", value));
+ EXPECT_EQ("123456.789", value);
+ EXPECT_TRUE(parser.parse("-123456.789", value));
+ EXPECT_EQ("-123456.789", value);
+ EXPECT_TRUE(parser.parse("9.87654e+06", value));
+ EXPECT_EQ("9.87654e+06", value);
+
+ // Characters
+ EXPECT_TRUE(parser.parse("E", value));
+ EXPECT_EQ("E", value);
+ EXPECT_TRUE(parser.parse("a", value));
+ EXPECT_EQ("a", value);
+
+ // Strings
+ EXPECT_TRUE(parser.parse("Test", value));
+ EXPECT_EQ("Test", value);
+}
+
+TEST(SerializeTest, ShowParamInt8)
+{
+ ShowParam<int8_t> parser;
+ std::stringstream ss;
+
+ parser.show(ss, 0);
+ EXPECT_EQ("0", ss.str());
+ ss.str("");
+ parser.show(ss, 127);
+ EXPECT_EQ("127", ss.str());
+ ss.str("");
+ parser.show(ss, -128);
+ EXPECT_EQ("-128", ss.str());
+ ss.str("");
+}
+
+TEST(SerializeTest, ShowParamUint32)
+{
+ ShowParam<uint32_t> parser;
+ std::stringstream ss;
+
+ parser.show(ss, 0);
+ EXPECT_EQ("0", ss.str());
+ ss.str("");
+ parser.show(ss, 255);
+ EXPECT_EQ("255", ss.str());
+ ss.str("");
+ parser.show(ss, 1000);
+ EXPECT_EQ("1000", ss.str());
+ ss.str("");
+ parser.show(ss, 2147483648);
+ EXPECT_EQ("2147483648", ss.str());
+ ss.str("");
+ parser.show(ss, 123456.789);
+ EXPECT_EQ("123456", ss.str());
+ ss.str("");
+ parser.show(ss, 9.87654e+06);
+ EXPECT_EQ("9876540", ss.str());
+ ss.str("");
+}
+
+/**
+ * Test converting doubles to strings. Floating numbers are expected to
+ * have 6-digit precision.
+ */
+TEST(SerializeTest, ShowParamDouble)
+{
+ ShowParam<double> parser;
+ std::stringstream ss;
+
+ parser.show(ss, 0);
+ EXPECT_EQ("0", ss.str());
+ ss.str("");
+ parser.show(ss, 255);
+ EXPECT_EQ("255", ss.str());
+ ss.str("");
+ parser.show(ss, -1000);
+ EXPECT_EQ("-1000", ss.str());
+ ss.str("");
+ parser.show(ss, 123456.789);
+ EXPECT_EQ("123457", ss.str());
+ ss.str("");
+ parser.show(ss, -123456.789);
+ EXPECT_EQ("-123457", ss.str());
+ ss.str("");
+ parser.show(ss, 1234567.89);
+ EXPECT_EQ("1.23457e+06", ss.str());
+ ss.str("");
+ parser.show(ss, -1234567.89);
+ EXPECT_EQ("-1.23457e+06", ss.str());
+ ss.str("");
+ parser.show(ss, 9.87654e+06);
+ EXPECT_EQ("9.87654e+06", ss.str());
+ ss.str("");
+}
+
+TEST(SerializeTest, ShowParamBool)
+{
+ ShowParam<bool> parser;
+ std::stringstream ss;
+
+ parser.show(ss, true);
+ EXPECT_EQ("true", ss.str());
+ ss.str("");
+ parser.show(ss, false);
+ EXPECT_EQ("false", ss.str());
+ ss.str("");
+}
+
+TEST(SerializeTest, ShowParamChar)
+{
+ ShowParam<char> parser;
+ std::stringstream ss;
+
+ parser.show(ss, 'E');
+ EXPECT_EQ("69", ss.str()); // int('E')=69
+ ss.str("");
+ parser.show(ss, 'a');
+ EXPECT_EQ("97", ss.str()); // int('a')=97
+ ss.str("");
+}
+
+TEST(SerializeTest, ShowParamString)
+{
+ ShowParam<std::string> parser;
+ std::stringstream ss;
+
+ parser.show(ss, "test");
+ EXPECT_EQ("test", ss.str());
+ ss.str("");
+ parser.show(ss, "tEsT");
+ EXPECT_EQ("tEsT", ss.str());
+ ss.str("");
+}
--
To view, visit https://gem5-review.googlesource.com/c/public/gem5/+/38776
To unsubscribe, or for help writing mail filters, visit
https://gem5-review.googlesource.com/settings
Gerrit-Project: public/gem5
Gerrit-Branch: develop
Gerrit-Change-Id: I1128c7adb12a3c7d091e26db13733ba45e1e61fe
Gerrit-Change-Number: 38776
Gerrit-PatchSet: 1
Gerrit-Owner: Daniel Carvalho <oda...@yahoo.com.br>
Gerrit-MessageType: newchange
_______________________________________________
gem5-dev mailing list -- gem5-dev@gem5.org
To unsubscribe send an email to gem5-dev-le...@gem5.org
%(web_page_url)slistinfo%(cgiext)s/%(_internal_name)s