mirror of
https://github.com/akuker/RASCSI.git
synced 2024-11-29 01:49:19 +00:00
a6a8cadf21
* Revert "Don't ResizeCache on sector change if no filename is defined (#1438)" This reverts commitdd9a3296d4
. * Revert "Add ModeSense page 0x25 (DEC special function control page) (#1412)" This reverts commit1121b8d9d6
. * Revert "DiskCache needs a size" This reverts commit7cc8df271c
. * Revert "Honor sector size change via ModeSelect6 in scsicd (#1406)" This reverts commitb7f65d33e2
. * Revert "Multiple fixes for ModeSelect (#1405)" This reverts commitad5eae93e7
.
128 lines
3.2 KiB
C++
128 lines
3.2 KiB
C++
//---------------------------------------------------------------------------
|
|
//
|
|
// SCSI Target Emulator PiSCSI
|
|
// for Raspberry Pi
|
|
//
|
|
// Copyright (C) 2022-2023 Uwe Seimet
|
|
//
|
|
//---------------------------------------------------------------------------
|
|
|
|
#include "mocks.h"
|
|
#include "shared/piscsi_exceptions.h"
|
|
#include "devices/scsihd.h"
|
|
|
|
void ScsiHdTest_SetUpModePages(map<int, vector<byte>>& pages)
|
|
{
|
|
EXPECT_EQ(5, pages.size()) << "Unexpected number of mode pages";
|
|
EXPECT_EQ(12, pages[1].size());
|
|
EXPECT_EQ(24, pages[3].size());
|
|
EXPECT_EQ(24, pages[4].size());
|
|
EXPECT_EQ(12, pages[8].size());
|
|
EXPECT_EQ(30, pages[48].size());
|
|
}
|
|
|
|
TEST(ScsiHdTest, Inquiry)
|
|
{
|
|
TestInquiry::Inquiry(SCHD, device_type::direct_access, scsi_level::scsi_2, "PiSCSI ", 0x1f, false);
|
|
|
|
TestInquiry::Inquiry(SCHD, device_type::direct_access, scsi_level::scsi_1_ccs, "PiSCSI ", 0x1f, false, "file.hd1");
|
|
}
|
|
|
|
TEST(ScsiHdTest, SupportsSaveParameters)
|
|
{
|
|
MockSCSIHD hd(0, false);
|
|
|
|
EXPECT_TRUE(hd.SupportsSaveParameters());
|
|
}
|
|
|
|
TEST(ScsiHdTest, FinalizeSetup)
|
|
{
|
|
MockSCSIHD hd(0, false);
|
|
|
|
hd.SetSectorSizeInBytes(1024);
|
|
EXPECT_THROW(hd.FinalizeSetup(0), io_exception) << "Device has 0 blocks";
|
|
}
|
|
|
|
TEST(ScsiHdTest, GetProductData)
|
|
{
|
|
MockSCSIHD hd_kb(0, false);
|
|
MockSCSIHD hd_mb(0, false);
|
|
MockSCSIHD hd_gb(0, false);
|
|
|
|
const path filename = CreateTempFile(1);
|
|
hd_kb.SetFilename(string(filename));
|
|
hd_kb.SetSectorSizeInBytes(1024);
|
|
hd_kb.SetBlockCount(1);
|
|
hd_kb.FinalizeSetup(0);
|
|
string s = hd_kb.GetProduct();
|
|
EXPECT_NE(string::npos, s.find("1 KiB"));
|
|
|
|
hd_mb.SetFilename(string(filename));
|
|
hd_mb.SetSectorSizeInBytes(1024);
|
|
hd_mb.SetBlockCount(1'048'576 / 1024);
|
|
hd_mb.FinalizeSetup(0);
|
|
s = hd_mb.GetProduct();
|
|
EXPECT_NE(string::npos, s.find("1 MiB"));
|
|
|
|
hd_gb.SetFilename(string(filename));
|
|
hd_gb.SetSectorSizeInBytes(1024);
|
|
hd_gb.SetBlockCount(10'737'418'240 / 1024);
|
|
hd_gb.FinalizeSetup(0);
|
|
s = hd_gb.GetProduct();
|
|
EXPECT_NE(string::npos, s.find("10 GiB"));
|
|
remove(filename);
|
|
}
|
|
|
|
TEST(ScsiHdTest, GetSectorSizes)
|
|
{
|
|
MockSCSIHD hd(0, false);
|
|
|
|
const auto& sector_sizes = hd.GetSupportedSectorSizes();
|
|
EXPECT_EQ(4, sector_sizes.size());
|
|
|
|
EXPECT_TRUE(sector_sizes.contains(512));
|
|
EXPECT_TRUE(sector_sizes.contains(1024));
|
|
EXPECT_TRUE(sector_sizes.contains(2048));
|
|
EXPECT_TRUE(sector_sizes.contains(4096));
|
|
}
|
|
|
|
TEST(ScsiHdTest, SetUpModePages)
|
|
{
|
|
map<int, vector<byte>> pages;
|
|
MockSCSIHD hd(0, false);
|
|
|
|
// Non changeable
|
|
hd.SetUpModePages(pages, 0x3f, false);
|
|
ScsiHdTest_SetUpModePages(pages);
|
|
|
|
// Changeable
|
|
pages.clear();
|
|
hd.SetUpModePages(pages, 0x3f, true);
|
|
ScsiHdTest_SetUpModePages(pages);
|
|
}
|
|
|
|
TEST(ScsiHdTest, ModeSelect)
|
|
{
|
|
MockSCSIHD hd({ 512 });
|
|
vector<int> cmd(10);
|
|
vector<uint8_t> buf(255);
|
|
|
|
hd.SetSectorSizeInBytes(512);
|
|
|
|
// PF
|
|
cmd[1] = 0x10;
|
|
// Page 3 (Device Format Page)
|
|
buf[4] = 0x03;
|
|
// 512 bytes per sector
|
|
buf[16] = 0x02;
|
|
EXPECT_NO_THROW(hd.ModeSelect(scsi_command::eCmdModeSelect6, cmd, buf, 255)) << "MODE SELECT(6) is supported";
|
|
buf[4] = 0;
|
|
buf[16] = 0;
|
|
|
|
// Page 3 (Device Format Page)
|
|
buf[8] = 0x03;
|
|
// 512 bytes per sector
|
|
buf[20] = 0x02;
|
|
EXPECT_NO_THROW(hd.ModeSelect(scsi_command::eCmdModeSelect10, cmd, buf, 255)) << "MODE SELECT(10) is supported";
|
|
}
|