2022-10-08 19:26:04 +02:00
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
//
|
2022-12-05 09:58:23 -08:00
|
|
|
// SCSI Target Emulator PiSCSI
|
2022-10-08 19:26:04 +02:00
|
|
|
// for Raspberry Pi
|
|
|
|
//
|
2023-10-15 08:38:15 +02:00
|
|
|
// Copyright (C) 2022-2023 Uwe Seimet
|
2022-10-08 19:26:04 +02:00
|
|
|
//
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#include "mocks.h"
|
2022-12-05 09:58:23 -08:00
|
|
|
#include "shared/piscsi_exceptions.h"
|
2022-10-25 10:29:57 +02:00
|
|
|
#include <filesystem>
|
|
|
|
#include <fstream>
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
using namespace filesystem;
|
|
|
|
|
|
|
|
void ScsiCdTest_SetUpModePages(map<int, vector<byte>>& pages)
|
|
|
|
{
|
|
|
|
EXPECT_EQ(7, 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(8, pages[13].size());
|
|
|
|
EXPECT_EQ(16, pages[14].size());
|
|
|
|
EXPECT_EQ(30, pages[48].size());
|
|
|
|
}
|
2022-10-08 19:26:04 +02:00
|
|
|
|
|
|
|
TEST(ScsiCdTest, Inquiry)
|
|
|
|
{
|
2023-10-15 08:38:15 +02:00
|
|
|
TestInquiry::Inquiry(SCCD, device_type::cd_rom, scsi_level::scsi_2, "PiSCSI SCSI CD-ROM ", 0x1f, true);
|
2023-02-26 21:52:19 -05:00
|
|
|
|
2023-10-15 08:38:15 +02:00
|
|
|
TestInquiry::Inquiry(SCCD, device_type::cd_rom, scsi_level::scsi_1_ccs, "PiSCSI SCSI CD-ROM ", 0x1f, true, "file.is1");
|
2022-10-23 21:51:39 +02:00
|
|
|
}
|
|
|
|
|
2023-11-14 15:32:46 +01:00
|
|
|
TEST(ScsiCdTest, GetSectorSizes)
|
|
|
|
{
|
|
|
|
MockSCSICD cd(0);
|
|
|
|
|
|
|
|
const auto& sector_sizes = cd.GetSupportedSectorSizes();
|
|
|
|
EXPECT_EQ(2, sector_sizes.size());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sector_sizes.contains(512));
|
|
|
|
EXPECT_TRUE(sector_sizes.contains(2048));
|
|
|
|
}
|
|
|
|
|
2022-10-08 19:26:04 +02:00
|
|
|
TEST(ScsiCdTest, SetUpModePages)
|
|
|
|
{
|
2022-10-23 21:51:39 +02:00
|
|
|
map<int, vector<byte>> pages;
|
2023-11-14 15:32:46 +01:00
|
|
|
MockSCSICD cd(0);
|
2022-10-08 19:26:04 +02:00
|
|
|
|
2022-10-25 10:29:57 +02:00
|
|
|
// Non changeable
|
2022-10-23 21:51:39 +02:00
|
|
|
cd.SetUpModePages(pages, 0x3f, false);
|
2022-10-25 10:29:57 +02:00
|
|
|
ScsiCdTest_SetUpModePages(pages);
|
|
|
|
|
|
|
|
// Changeable
|
|
|
|
pages.clear();
|
|
|
|
cd.SetUpModePages(pages, 0x3f, true);
|
|
|
|
ScsiCdTest_SetUpModePages(pages);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(ScsiCdTest, Open)
|
|
|
|
{
|
2023-11-14 15:32:46 +01:00
|
|
|
MockSCSICD cd_iso(0);
|
|
|
|
MockSCSICD cd_cue(0);
|
|
|
|
MockSCSICD cd_raw(0);
|
|
|
|
MockSCSICD cd_physical(0);
|
2022-10-25 10:29:57 +02:00
|
|
|
|
|
|
|
EXPECT_THROW(cd_iso.Open(), io_exception) << "Missing filename";
|
|
|
|
|
|
|
|
path filename = CreateTempFile(2047);
|
|
|
|
cd_iso.SetFilename(string(filename));
|
|
|
|
EXPECT_THROW(cd_iso.Open(), io_exception) << "ISO CD-ROM image file size too small";
|
|
|
|
remove(filename);
|
|
|
|
|
|
|
|
filename = CreateTempFile(2* 2048);
|
|
|
|
cd_iso.SetFilename(string(filename));
|
|
|
|
cd_iso.Open();
|
|
|
|
EXPECT_EQ(2, cd_iso.GetBlockCount());
|
|
|
|
remove(filename);
|
|
|
|
|
|
|
|
filename = CreateTempFile(0);
|
|
|
|
ofstream out;
|
|
|
|
out.open(filename);
|
|
|
|
array<char, 4> cue = { 'F', 'I', 'L', 'E' };
|
|
|
|
out.write(cue.data(), cue.size());
|
|
|
|
out.close();
|
|
|
|
resize_file(filename, 2 * 2048);
|
|
|
|
cd_cue.SetFilename(string(filename));
|
|
|
|
EXPECT_THROW(cd_cue.Open(), io_exception) << "CUE CD-ROM files are not supported";
|
|
|
|
|
|
|
|
filename = CreateTempFile(0);
|
|
|
|
out.open(filename);
|
|
|
|
array<char, 16> header;
|
|
|
|
header.fill(0xff);
|
|
|
|
header[0] = 0;
|
|
|
|
header[11] = 0;
|
|
|
|
out.write(header.data(), header.size());
|
|
|
|
out.close();
|
|
|
|
resize_file(filename, 2 * 2535);
|
|
|
|
cd_raw.SetFilename(string(filename));
|
|
|
|
EXPECT_THROW(cd_raw.Open(), io_exception) << "Illegal raw ISO CD-ROM header";
|
|
|
|
header[15] = 0x01;
|
|
|
|
filename = CreateTempFile(0);
|
|
|
|
out.open(filename);
|
|
|
|
out.write(header.data(), header.size());
|
|
|
|
out.close();
|
|
|
|
cd_raw.SetFilename(string(filename));
|
|
|
|
resize_file(filename, 2 * 2536);
|
|
|
|
cd_raw.Open();
|
|
|
|
EXPECT_EQ(2, cd_raw.GetBlockCount());
|
|
|
|
remove(filename);
|
|
|
|
|
|
|
|
filename = CreateTempFile(2* 2048);
|
|
|
|
cd_physical.SetFilename("\\" + string(filename));
|
2022-12-05 09:58:23 -08:00
|
|
|
// The respective code in SCSICD appears to be broken, see https://github.com/akuker/PISCSI/issues/919
|
2022-10-25 10:29:57 +02:00
|
|
|
EXPECT_THROW(cd_physical.Open(), io_exception) << "Invalid physical CD-ROM file";
|
|
|
|
remove(filename);
|
2022-10-23 21:51:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(ScsiCdTest, ReadToc)
|
|
|
|
{
|
2023-10-15 08:38:15 +02:00
|
|
|
auto controller = make_shared<MockAbstractController>();
|
2023-11-14 15:32:46 +01:00
|
|
|
auto cd = make_shared<MockSCSICD>(0);
|
2023-10-15 08:38:15 +02:00
|
|
|
EXPECT_TRUE(cd->Init({}));
|
2022-10-23 21:51:39 +02:00
|
|
|
|
2022-11-04 08:22:32 +01:00
|
|
|
controller->AddDevice(cd);
|
2022-10-23 21:51:39 +02:00
|
|
|
|
2022-11-02 07:36:25 +01:00
|
|
|
EXPECT_THAT([&] { cd->Dispatch(scsi_command::eCmdReadToc); }, Throws<scsi_exception>(AllOf(
|
2023-10-15 08:38:15 +02:00
|
|
|
Property(&scsi_exception::get_sense_key, sense_key::not_ready),
|
|
|
|
Property(&scsi_exception::get_asc, asc::medium_not_present))));
|
2022-10-23 21:51:39 +02:00
|
|
|
|
|
|
|
// Further testing requires filesystem access
|
2022-10-08 19:26:04 +02:00
|
|
|
}
|