mirror of
https://github.com/mfontanini/libtins
synced 2026-01-29 13:04:28 +01:00
Added several Dot11 tests, fixed some bugs on Dot11.
This commit is contained in:
82
tests/src/dot11/reassoc_request.cpp
Normal file
82
tests/src/dot11/reassoc_request.cpp
Normal file
@@ -0,0 +1,82 @@
|
||||
#include <gtest/gtest.h>
|
||||
#include <algorithm>
|
||||
#include <memory>
|
||||
#include <stdint.h>
|
||||
#include "dot11.h"
|
||||
#include "tests/dot11.h"
|
||||
|
||||
|
||||
using namespace std;
|
||||
using namespace Tins;
|
||||
|
||||
typedef Dot11::address_type address_type;
|
||||
|
||||
class Dot11ReAssocRequestTest : public testing::Test {
|
||||
public:
|
||||
static const address_type empty_addr, hwaddr;
|
||||
static const uint8_t expected_packet[];
|
||||
};
|
||||
|
||||
const uint8_t Dot11ReAssocRequestTest::expected_packet[] = {
|
||||
'!', '\x01', 'O', '#', '\x00', '\x01', '\x02', '\x03', '\x04',
|
||||
'\x05', '\x01', '\x02', '\x03', '\x04', '\x05', '\x06', '\x02',
|
||||
'\x03', '\x04', '\x05', '\x06', '\x07', '\x00', '\x00', '\x15',
|
||||
' ', '\xf3', '\x92', '\x03', '\x04', '\x05', '\x06', '\x07', '\x08'
|
||||
};
|
||||
|
||||
void test_equals(const Dot11ReAssocRequest &dot1, const Dot11ReAssocRequest &dot2) {
|
||||
test_equals(dot1.capabilities(), dot2.capabilities());
|
||||
EXPECT_EQ(dot1.listen_interval(), dot2.listen_interval());
|
||||
EXPECT_EQ(dot1.current_ap(), dot2.current_ap());
|
||||
test_equals(
|
||||
static_cast<const Dot11ManagementFrame&>(dot1),
|
||||
static_cast<const Dot11ManagementFrame&>(dot2)
|
||||
);
|
||||
}
|
||||
|
||||
void test_equals_expected(const Dot11ReAssocRequest &dot11) {
|
||||
test_equals_expected(static_cast<const Dot11ManagementFrame&>(dot11));
|
||||
EXPECT_EQ(dot11.listen_interval(), 0x92f3);
|
||||
EXPECT_EQ(dot11.subtype(), Dot11::REASSOC_REQ);
|
||||
}
|
||||
|
||||
TEST_F(Dot11ReAssocRequestTest, Constructor) {
|
||||
Dot11ReAssocRequest dot11;
|
||||
test_equals_empty(static_cast<const Dot11ManagementFrame&>(dot11));
|
||||
EXPECT_EQ(dot11.listen_interval(), 0);
|
||||
EXPECT_EQ(dot11.current_ap(), address_type());
|
||||
EXPECT_EQ(dot11.subtype(), Dot11::REASSOC_REQ);
|
||||
}
|
||||
|
||||
TEST_F(Dot11ReAssocRequestTest, ConstructorFromBuffer) {
|
||||
Dot11ReAssocRequest dot11(expected_packet, sizeof(expected_packet));
|
||||
test_equals_expected(dot11);
|
||||
}
|
||||
|
||||
TEST_F(Dot11ReAssocRequestTest, CopyConstructor) {
|
||||
Dot11ReAssocRequest dot1(expected_packet, sizeof(expected_packet));
|
||||
Dot11ReAssocRequest dot2(dot1);
|
||||
test_equals(dot1, dot2);
|
||||
}
|
||||
|
||||
TEST_F(Dot11ReAssocRequestTest, CopyAssignmentOperator) {
|
||||
Dot11ReAssocRequest dot1(expected_packet, sizeof(expected_packet));
|
||||
Dot11ReAssocRequest dot2;
|
||||
dot2 = dot1;
|
||||
test_equals(dot1, dot2);
|
||||
}
|
||||
|
||||
TEST_F(Dot11ReAssocRequestTest, ClonePDU) {
|
||||
Dot11ReAssocRequest dot1(expected_packet, sizeof(expected_packet));
|
||||
std::auto_ptr<Dot11ReAssocRequest> dot2(dot1.clone_pdu());
|
||||
test_equals(dot1, *dot2);
|
||||
}
|
||||
|
||||
TEST_F(Dot11ReAssocRequestTest, FromBytes) {
|
||||
std::auto_ptr<PDU> dot11(Dot11::from_bytes(expected_packet, sizeof(expected_packet)));
|
||||
ASSERT_TRUE(dot11.get());
|
||||
const Dot11ReAssocRequest *inner = dot11->find_inner_pdu<Dot11ReAssocRequest>();
|
||||
ASSERT_TRUE(inner);
|
||||
test_equals_expected(*inner);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user