diff options
author | Clyne Sullivan <clyne@clyne-lp.lan> | 2021-08-08 22:02:52 -0400 |
---|---|---|
committer | Clyne Sullivan <clyne@clyne-lp.lan> | 2021-08-08 22:02:52 -0400 |
commit | 707b24dd07236243269cf092728f85172e94e8a4 (patch) | |
tree | c136716a5fc9ed9cbf570e24f8f6ab715adc73a2 /source/serial/tests/unix_serial_tests.cc |
initial commit
Diffstat (limited to 'source/serial/tests/unix_serial_tests.cc')
-rw-r--r-- | source/serial/tests/unix_serial_tests.cc | 118 |
1 files changed, 118 insertions, 0 deletions
diff --git a/source/serial/tests/unix_serial_tests.cc b/source/serial/tests/unix_serial_tests.cc new file mode 100644 index 0000000..26ffde2 --- /dev/null +++ b/source/serial/tests/unix_serial_tests.cc @@ -0,0 +1,118 @@ +/* To run these tests you need to change the define below to the serial port + * with a loop back device attached. + * + * Alternatively you could use an Arduino: + +void setup() +{ + Serial.begin(115200); +} + +void loop() +{ + while (Serial.available() > 0) { + Serial.write(Serial.read()); + } +} + +*/ + +#include <string> +#include "gtest/gtest.h" + +#include <boost/bind.hpp> + +// Use FRIEND_TEST... its not as nasty, thats what friends are for +// // OMG this is so nasty... +// #define private public +// #define protected public + +#include "serial/serial.h" + +#if defined(__linux__) +#include <pty.h> +#else +#include <util.h> +#endif + +using namespace serial; + +using std::string; + +namespace { + +class SerialTests : public ::testing::Test { +protected: + virtual void SetUp() { + if (openpty(&master_fd, &slave_fd, name, NULL, NULL) == -1) { + perror("openpty"); + exit(127); + } + + ASSERT_TRUE(master_fd > 0); + ASSERT_TRUE(slave_fd > 0); + ASSERT_TRUE(string(name).length() > 0); + + port1 = new Serial(string(name), 115200, Timeout::simpleTimeout(250)); + } + + virtual void TearDown() { + port1->close(); + delete port1; + } + + Serial * port1; + int master_fd; + int slave_fd; + char name[100]; +}; + +TEST_F(SerialTests, readWorks) { + write(master_fd, "abc\n", 4); + string r = port1->read(4); + EXPECT_EQ(r, string("abc\n")); +} + +TEST_F(SerialTests, writeWorks) { + char buf[5] = ""; + port1->write("abc\n"); + read(master_fd, buf, 4); + EXPECT_EQ(string(buf, 4), string("abc\n")); +} + +TEST_F(SerialTests, timeoutWorks) { + // Timeout a read, returns an empty string + string empty = port1->read(); + EXPECT_EQ(empty, string("")); + + // Ensure that writing/reading still works after a timeout. + write(master_fd, "abc\n", 4); + string r = port1->read(4); + EXPECT_EQ(r, string("abc\n")); +} + +TEST_F(SerialTests, partialRead) { + // Write some data, but request more than was written. + write(master_fd, "abc\n", 4); + + // Should timeout, but return what was in the buffer. + string empty = port1->read(10); + EXPECT_EQ(empty, string("abc\n")); + + // Ensure that writing/reading still works after a timeout. + write(master_fd, "abc\n", 4); + string r = port1->read(4); + EXPECT_EQ(r, string("abc\n")); +} + +} // namespace + +int main(int argc, char **argv) { + try { + ::testing::InitGoogleTest(&argc, argv); + return RUN_ALL_TESTS(); + } catch (std::exception &e) { + std::cerr << "Unhandled Exception: " << e.what() << std::endl; + } + return 1; +} |