Skip to content

Commit 6533d0c

Browse files
committed
selftests/landlock: Test landlock_create_ruleset(2) argument check ordering
Add inval_create_ruleset_arguments, extension of inval_create_ruleset_flags, to also check error ordering for landlock_create_ruleset(2). This is similar to the previous commit checking landlock_add_rule(2). Test coverage for security/landlock is 94.4% of 504 lines accorging to gcc/gcov-11. Link: https://lore.kernel.org/r/20220506160820.524344-11-mic@digikod.net Cc: stable@vger.kernel.org Signed-off-by: Mickaël Salaün <mic@digikod.net>
1 parent eba39ca commit 6533d0c

1 file changed

Lines changed: 20 additions & 1 deletion

File tree

tools/testing/selftests/landlock/base_test.c

Lines changed: 20 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -97,14 +97,17 @@ TEST(abi_version)
9797
ASSERT_EQ(EINVAL, errno);
9898
}
9999

100-
TEST(inval_create_ruleset_flags)
100+
/* Tests ordering of syscall argument checks. */
101+
TEST(create_ruleset_checks_ordering)
101102
{
102103
const int last_flag = LANDLOCK_CREATE_RULESET_VERSION;
103104
const int invalid_flag = last_flag << 1;
105+
int ruleset_fd;
104106
const struct landlock_ruleset_attr ruleset_attr = {
105107
.handled_access_fs = LANDLOCK_ACCESS_FS_READ_FILE,
106108
};
107109

110+
/* Checks priority for invalid flags. */
108111
ASSERT_EQ(-1, landlock_create_ruleset(NULL, 0, invalid_flag));
109112
ASSERT_EQ(EINVAL, errno);
110113

@@ -119,6 +122,22 @@ TEST(inval_create_ruleset_flags)
119122
landlock_create_ruleset(&ruleset_attr, sizeof(ruleset_attr),
120123
invalid_flag));
121124
ASSERT_EQ(EINVAL, errno);
125+
126+
/* Checks too big ruleset_attr size. */
127+
ASSERT_EQ(-1, landlock_create_ruleset(&ruleset_attr, -1, 0));
128+
ASSERT_EQ(E2BIG, errno);
129+
130+
/* Checks too small ruleset_attr size. */
131+
ASSERT_EQ(-1, landlock_create_ruleset(&ruleset_attr, 0, 0));
132+
ASSERT_EQ(EINVAL, errno);
133+
ASSERT_EQ(-1, landlock_create_ruleset(&ruleset_attr, 1, 0));
134+
ASSERT_EQ(EINVAL, errno);
135+
136+
/* Checks valid call. */
137+
ruleset_fd =
138+
landlock_create_ruleset(&ruleset_attr, sizeof(ruleset_attr), 0);
139+
ASSERT_LE(0, ruleset_fd);
140+
ASSERT_EQ(0, close(ruleset_fd));
122141
}
123142

124143
/* Tests ordering of syscall argument checks. */

0 commit comments

Comments
 (0)