forked from ceph/ceph
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_blkdev.cc
93 lines (76 loc) · 2.18 KB
/
test_blkdev.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
// vim: ts=8 sw=2 smarttab
#include <string.h>
#include <errno.h>
#include <stdlib.h>
#include <linux/kdev_t.h>
#include "include/types.h"
#include "common/blkdev.h"
#include "gtest/gtest.h"
#include "gmock/gmock.h"
#include <iostream>
using namespace std;
using namespace testing;
class MockBlkDev : public BlkDev {
public:
// pass 0 as fd, so it won't try to use the empty devname
MockBlkDev() : BlkDev(0) {};
virtual ~MockBlkDev() {}
MOCK_CONST_METHOD0(sysfsdir, const char*());
MOCK_CONST_METHOD2(wholedisk, int(char* device, size_t max));
};
class BlockDevTest : public ::testing::Test {
public:
string *root;
protected:
virtual void SetUp() {
const char *sda_name = "sda";
const char *sdb_name = "sdb";
const char* env = getenv("CEPH_ROOT");
ASSERT_NE(env, nullptr) << "Environment Variable CEPH_ROOT not found!";
root = new string(env);
*root += "/src/test/common/test_blkdev_sys_block/sys";
EXPECT_CALL(sda, sysfsdir())
.WillRepeatedly(Return(root->c_str()));
EXPECT_CALL(sda, wholedisk(NotNull(), Ge(0ul)))
.WillRepeatedly(
DoAll(
SetArrayArgument<0>(sda_name, sda_name + strlen(sda_name) + 1),
Return(0)));
EXPECT_CALL(sdb, sysfsdir())
.WillRepeatedly(Return(root->c_str()));
EXPECT_CALL(sdb, wholedisk(NotNull(), Ge(0ul)))
.WillRepeatedly(
DoAll(
SetArrayArgument<0>(sdb_name, sdb_name + strlen(sdb_name) + 1),
Return(0)));
}
virtual void TearDown() {
delete root;
}
MockBlkDev sda, sdb;
};
TEST_F(BlockDevTest, device_model)
{
char model[1000] = {0};
int rc = sda.model(model, sizeof(model));
ASSERT_EQ(0, rc);
ASSERT_STREQ(model, "myfancymodel");
}
TEST_F(BlockDevTest, discard)
{
EXPECT_TRUE(sda.support_discard());
EXPECT_TRUE(sdb.support_discard());
}
TEST_F(BlockDevTest, is_nvme)
{
// It would be nice to have a positive NVME test too, but I don't have any
// examples for the canned data.
EXPECT_FALSE(sda.is_nvme());
EXPECT_FALSE(sdb.is_nvme());
}
TEST_F(BlockDevTest, is_rotational)
{
EXPECT_FALSE(sda.is_rotational());
EXPECT_TRUE(sdb.is_rotational());
}