aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--test/gtest/test_tle_udp_dev.cpp24
-rw-r--r--test/gtest/test_tle_udp_dev.h9
2 files changed, 31 insertions, 2 deletions
diff --git a/test/gtest/test_tle_udp_dev.cpp b/test/gtest/test_tle_udp_dev.cpp
index 8efb866..a58186e 100644
--- a/test/gtest/test_tle_udp_dev.cpp
+++ b/test/gtest/test_tle_udp_dev.cpp
@@ -53,6 +53,7 @@ TEST_F(udp_dev, udp_dev_add_only_ipv4)
dev = tle_udp_add_dev(ctx, &dev_prm);
ASSERT_NE(dev, (void *) NULL);
EXPECT_EQ(rte_errno, 0);
+ devs.push_back(dev);
}
TEST_F(udp_dev, udp_dev_add_only_ipv6)
@@ -70,6 +71,7 @@ TEST_F(udp_dev, udp_dev_add_nonexist_ipv4)
dev = tle_udp_add_dev(ctx, &dev_prm);
ASSERT_NE(dev, (void *) NULL);
EXPECT_EQ(rte_errno, 0);
+ devs.push_back(dev);
}
TEST_F(udp_dev, udp_dev_add_positive)
@@ -77,9 +79,21 @@ TEST_F(udp_dev, udp_dev_add_positive)
dev = tle_udp_add_dev(ctx, &dev_prm);
ASSERT_NE(dev, (void *) NULL);
EXPECT_EQ(rte_errno, 0);
+ devs.push_back(dev);
+}
+
+TEST_F(udp_dev, udp_dev_add_max)
+{
+ int i;
+ for(i = 0; i < RTE_MAX_ETHPORTS; i++) {
+ dev = tle_udp_add_dev(ctx, &dev_prm);
+ ASSERT_NE(dev, (void *) NULL);
+ EXPECT_EQ(rte_errno, 0);
+ devs.push_back(dev);
+ }
dev = tle_udp_add_dev(ctx, &dev_prm);
- ASSERT_NE(dev, (void *) NULL);
- EXPECT_EQ(rte_errno, 0);
+ ASSERT_EQ(dev, (void *) NULL);
+ EXPECT_EQ(rte_errno, ENODEV);
}
TEST_F(udp_dev, udp_dev_del_positive)
@@ -87,6 +101,12 @@ TEST_F(udp_dev, udp_dev_del_positive)
dev = tle_udp_add_dev(ctx, &dev_prm);
ASSERT_NE(dev, (void *) NULL);
EXPECT_EQ(rte_errno, 0);
+ devs.push_back(dev);
ASSERT_EQ(tle_udp_del_dev(dev), 0);
EXPECT_EQ(rte_errno, 0);
}
+
+TEST_F(udp_dev, udp_dev_del_null_dev)
+{
+ ASSERT_EQ(tle_udp_del_dev(dev), -EINVAL);
+}
diff --git a/test/gtest/test_tle_udp_dev.h b/test/gtest/test_tle_udp_dev.h
index 3ecc5c7..02f544d 100644
--- a/test/gtest/test_tle_udp_dev.h
+++ b/test/gtest/test_tle_udp_dev.h
@@ -16,14 +16,19 @@
#ifndef TEST_TLE_UDP_DEV_H_
#define TEST_TLE_UDP_DEV_H_
+#include <algorithm>
#include <arpa/inet.h>
#include <gtest/gtest.h>
+
#include <rte_errno.h>
+
#include <tle_udp_impl.h>
#define RX_NO_OFFLOAD 0
#define TX_NO_OFFLOAD 0
+using namespace std;
+
class udp_dev : public ::testing::Test {
public:
@@ -31,6 +36,7 @@ public:
struct tle_udp_dev *dev;
struct tle_udp_ctx_param prm;
struct tle_udp_dev_param dev_prm;
+ vector<tle_udp_dev*> devs;
virtual void SetUp(void)
{
@@ -56,6 +62,9 @@ public:
virtual void TearDown(void)
{
+ for(auto d : devs) {
+ tle_udp_del_dev(d);
+ }
tle_udp_destroy(ctx);
}
};