mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 03:07:44 +00:00
Tests/Kernel: Add test cases for proper types in dirent for various FSes
This commit is contained in:
parent
a10e63f08e
commit
90152dc859
2 changed files with 100 additions and 0 deletions
|
@ -41,6 +41,7 @@ set(LIBTEST_BASED_SOURCES
|
||||||
TestEmptyPrivateInodeVMObject.cpp
|
TestEmptyPrivateInodeVMObject.cpp
|
||||||
TestEmptySharedInodeVMObject.cpp
|
TestEmptySharedInodeVMObject.cpp
|
||||||
TestExt2FS.cpp
|
TestExt2FS.cpp
|
||||||
|
TestFileSystemDirentTypes.cpp
|
||||||
TestInvalidUIDSet.cpp
|
TestInvalidUIDSet.cpp
|
||||||
TestSharedInodeVMObject.cpp
|
TestSharedInodeVMObject.cpp
|
||||||
TestPosixFallocate.cpp
|
TestPosixFallocate.cpp
|
||||||
|
|
99
Tests/Kernel/TestFileSystemDirentTypes.cpp
Normal file
99
Tests/Kernel/TestFileSystemDirentTypes.cpp
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2024, Liav A. <liavalb@hotmail.co.il>
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <Kernel/API/POSIX/dirent.h>
|
||||||
|
#include <LibTest/TestCase.h>
|
||||||
|
#include <dirent.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
TEST_CASE(test_sysfs_root_directory)
|
||||||
|
{
|
||||||
|
auto dirfd = open("/sys/", O_RDONLY | O_DIRECTORY);
|
||||||
|
auto cleanup_guard = ScopeGuard([&] {
|
||||||
|
close(dirfd);
|
||||||
|
});
|
||||||
|
|
||||||
|
DIR* dir = fdopendir(dirfd);
|
||||||
|
EXPECT(dir != nullptr);
|
||||||
|
|
||||||
|
auto cleanup_dir_guard = ScopeGuard([&] {
|
||||||
|
closedir(dir);
|
||||||
|
});
|
||||||
|
|
||||||
|
auto* _dirent = readdir(dir);
|
||||||
|
EXPECT(_dirent != nullptr);
|
||||||
|
// NOTE: We should see '.'
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_DIR);
|
||||||
|
|
||||||
|
_dirent = readdir(dir);
|
||||||
|
EXPECT(_dirent != nullptr);
|
||||||
|
// NOTE: We should see '..'
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_DIR);
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
_dirent = readdir(dir);
|
||||||
|
if (_dirent == nullptr)
|
||||||
|
break;
|
||||||
|
// NOTE: We should only see a directory entry in the /sys directory
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_DIR);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE(test_devpts_root_directory)
|
||||||
|
{
|
||||||
|
auto dirfd = open("/dev/pts/", O_RDONLY | O_DIRECTORY);
|
||||||
|
auto cleanup_guard = ScopeGuard([&] {
|
||||||
|
close(dirfd);
|
||||||
|
});
|
||||||
|
|
||||||
|
DIR* dir = fdopendir(dirfd);
|
||||||
|
EXPECT(dir != nullptr);
|
||||||
|
|
||||||
|
auto cleanup_dir_guard = ScopeGuard([&] {
|
||||||
|
closedir(dir);
|
||||||
|
});
|
||||||
|
|
||||||
|
auto* _dirent = readdir(dir);
|
||||||
|
EXPECT(_dirent != nullptr);
|
||||||
|
// NOTE: We should see '.'
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_DIR);
|
||||||
|
|
||||||
|
_dirent = readdir(dir);
|
||||||
|
EXPECT(_dirent != nullptr);
|
||||||
|
// NOTE: We should see '..'
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_DIR);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE(test_procfs_root_directory)
|
||||||
|
{
|
||||||
|
auto dirfd = open("/proc/", O_RDONLY | O_DIRECTORY);
|
||||||
|
auto cleanup_guard = ScopeGuard([&] {
|
||||||
|
close(dirfd);
|
||||||
|
});
|
||||||
|
|
||||||
|
DIR* dir = fdopendir(dirfd);
|
||||||
|
EXPECT(dir != nullptr);
|
||||||
|
|
||||||
|
auto cleanup_dir_guard = ScopeGuard([&] {
|
||||||
|
closedir(dir);
|
||||||
|
});
|
||||||
|
|
||||||
|
auto* _dirent = readdir(dir);
|
||||||
|
EXPECT(_dirent != nullptr);
|
||||||
|
// NOTE: We should see '.' now
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_DIR);
|
||||||
|
|
||||||
|
_dirent = readdir(dir);
|
||||||
|
EXPECT(_dirent != nullptr);
|
||||||
|
// NOTE: We should see '..' now
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_DIR);
|
||||||
|
|
||||||
|
_dirent = readdir(dir);
|
||||||
|
EXPECT(_dirent != nullptr);
|
||||||
|
// NOTE: We should see 'self' now
|
||||||
|
EXPECT_EQ(_dirent->d_type, DT_LNK);
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue