2022-10-23 21:51:39 +02:00
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// SCSI Target Emulator RaSCSI Reloaded
|
|
|
|
// for Raspberry Pi
|
|
|
|
//
|
|
|
|
// Copyright (C) 2022 Uwe Seimet
|
|
|
|
//
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#include "mocks.h"
|
|
|
|
#include "rascsi_exceptions.h"
|
|
|
|
#include "devices/storage_device.h"
|
2022-10-25 10:29:57 +02:00
|
|
|
#include <filesystem>
|
|
|
|
|
|
|
|
using namespace filesystem;
|
2022-10-23 21:51:39 +02:00
|
|
|
|
|
|
|
TEST(StorageDeviceTest, Filename)
|
|
|
|
{
|
|
|
|
MockStorageDevice device;
|
|
|
|
|
|
|
|
device.SetFilename("filename");
|
|
|
|
EXPECT_EQ("filename", device.GetFilename());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, ValidateFile)
|
|
|
|
{
|
|
|
|
MockStorageDevice device;
|
|
|
|
|
|
|
|
device.SetBlockCount(0);
|
2022-10-25 10:29:57 +02:00
|
|
|
device.SetFilename("/non_existing_file");
|
|
|
|
EXPECT_THROW(device.ValidateFile(), io_exception);
|
|
|
|
|
|
|
|
device.SetBlockCount(1);
|
|
|
|
EXPECT_THROW(device.ValidateFile(), io_exception);
|
2022-10-23 21:51:39 +02:00
|
|
|
|
2022-10-25 10:29:57 +02:00
|
|
|
const path filename = CreateTempFile(1);
|
|
|
|
device.SetFilename(string(filename));
|
2022-10-23 21:51:39 +02:00
|
|
|
device.SetReadOnly(false);
|
|
|
|
device.SetProtectable(true);
|
2022-10-25 10:29:57 +02:00
|
|
|
device.ValidateFile();
|
|
|
|
EXPECT_FALSE(device.IsReadOnly());
|
|
|
|
EXPECT_TRUE(device.IsProtectable());
|
2022-10-23 21:51:39 +02:00
|
|
|
EXPECT_FALSE(device.IsStopped());
|
|
|
|
EXPECT_FALSE(device.IsRemoved());
|
|
|
|
EXPECT_FALSE(device.IsLocked());
|
|
|
|
|
2022-10-25 10:29:57 +02:00
|
|
|
permissions(filename, perms::owner_read);
|
2022-10-23 21:51:39 +02:00
|
|
|
device.SetReadOnly(false);
|
|
|
|
device.SetProtectable(true);
|
2022-10-25 10:29:57 +02:00
|
|
|
device.ValidateFile();
|
|
|
|
EXPECT_TRUE(device.IsReadOnly());
|
|
|
|
EXPECT_FALSE(device.IsProtectable());
|
|
|
|
EXPECT_FALSE(device.IsProtected());
|
2022-10-23 21:51:39 +02:00
|
|
|
EXPECT_FALSE(device.IsStopped());
|
|
|
|
EXPECT_FALSE(device.IsRemoved());
|
|
|
|
EXPECT_FALSE(device.IsLocked());
|
2022-10-25 10:29:57 +02:00
|
|
|
|
|
|
|
remove(filename);
|
2022-10-23 21:51:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, MediumChanged)
|
|
|
|
{
|
|
|
|
MockStorageDevice device;
|
|
|
|
|
|
|
|
device.SetMediumChanged(true);
|
|
|
|
EXPECT_TRUE(device.IsMediumChanged());
|
|
|
|
|
|
|
|
device.SetMediumChanged(false);
|
|
|
|
EXPECT_FALSE(device.IsMediumChanged());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, GetIdsForReservedFile)
|
|
|
|
{
|
|
|
|
const int ID = 1;
|
|
|
|
const int LUN = 2;
|
2022-10-25 10:29:57 +02:00
|
|
|
StorageDevice::UnreserveAll();
|
2022-10-23 21:51:39 +02:00
|
|
|
|
|
|
|
MockStorageDevice device;
|
|
|
|
device.SetFilename("filename");
|
|
|
|
|
2022-10-25 10:29:57 +02:00
|
|
|
const auto [id1, lun1] = StorageDevice::GetIdsForReservedFile("filename");
|
|
|
|
EXPECT_EQ(-1, id1);
|
|
|
|
EXPECT_EQ(-1, lun1);
|
2022-10-23 21:51:39 +02:00
|
|
|
|
|
|
|
device.ReserveFile("filename", ID, LUN);
|
2022-10-25 10:29:57 +02:00
|
|
|
const auto [id2, lun2] = StorageDevice::GetIdsForReservedFile("filename");
|
|
|
|
EXPECT_EQ(ID, id2);
|
|
|
|
EXPECT_EQ(LUN, lun2);
|
2022-10-23 21:51:39 +02:00
|
|
|
|
|
|
|
device.UnreserveFile();
|
2022-10-25 10:29:57 +02:00
|
|
|
const auto [id3, lun3] = StorageDevice::GetIdsForReservedFile("filename");
|
|
|
|
EXPECT_EQ(-1, id3);
|
|
|
|
EXPECT_EQ(-1, lun3);
|
2022-10-23 21:51:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, UnreserveAll)
|
|
|
|
{
|
|
|
|
MockStorageDevice device;
|
|
|
|
device.ReserveFile("filename", 2, 31);
|
|
|
|
|
|
|
|
StorageDevice::UnreserveAll();
|
2022-10-25 10:29:57 +02:00
|
|
|
const auto [id, lun] = StorageDevice::GetIdsForReservedFile("filename");
|
|
|
|
EXPECT_EQ(-1, id);
|
|
|
|
EXPECT_EQ(-1, lun);
|
2022-10-23 21:51:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, GetSetReservedFiles)
|
|
|
|
{
|
|
|
|
const int ID = 1;
|
|
|
|
const int LUN = 16;
|
|
|
|
|
|
|
|
MockStorageDevice device;
|
|
|
|
device.ReserveFile("filename", ID, LUN);
|
|
|
|
|
|
|
|
const unordered_map<string, id_set> reserved_files = StorageDevice::GetReservedFiles();
|
|
|
|
EXPECT_EQ(1, reserved_files.size());
|
|
|
|
EXPECT_NE(reserved_files.end(), reserved_files.find("filename"));
|
|
|
|
|
|
|
|
StorageDevice::SetReservedFiles(reserved_files);
|
|
|
|
EXPECT_EQ(1, reserved_files.size());
|
|
|
|
EXPECT_NE(reserved_files.end(), reserved_files.find("filename"));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, FileExists)
|
|
|
|
{
|
|
|
|
EXPECT_FALSE(StorageDevice::FileExists("/non_existing_file"));
|
|
|
|
EXPECT_TRUE(StorageDevice::FileExists("/dev/null"));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, IsReadOnlyFile)
|
|
|
|
{
|
|
|
|
MockStorageDevice device;
|
|
|
|
|
|
|
|
device.SetFilename("/dev/null");
|
|
|
|
EXPECT_FALSE(device.IsReadOnlyFile());
|
|
|
|
|
|
|
|
device.SetFilename("/dev/mem");
|
|
|
|
EXPECT_TRUE(device.IsReadOnlyFile());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(StorageDeviceTest, GetFileSize)
|
|
|
|
{
|
|
|
|
MockStorageDevice device;
|
|
|
|
|
2022-10-25 10:29:57 +02:00
|
|
|
const path filename = CreateTempFile(512);
|
|
|
|
device.SetFilename(filename.c_str());
|
2022-10-23 21:51:39 +02:00
|
|
|
const off_t size = device.GetFileSize();
|
2022-10-25 10:29:57 +02:00
|
|
|
remove(filename);
|
2022-10-23 21:51:39 +02:00
|
|
|
EXPECT_EQ(512, size);
|
|
|
|
|
|
|
|
device.SetFilename("/non_existing_file");
|
|
|
|
EXPECT_THROW(device.GetFileSize(), io_exception);
|
|
|
|
}
|