2022-10-23 21:51:39 +02:00
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
//
|
2022-12-05 09:58:23 -08:00
|
|
|
// SCSI Target Emulator PiSCSI
|
2022-10-23 21:51:39 +02:00
|
|
|
// for Raspberry Pi
|
|
|
|
//
|
|
|
|
// Copyright (C) 2022 Uwe Seimet
|
|
|
|
//
|
|
|
|
// These tests only test up the point where a network connection is required.
|
|
|
|
//
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
2022-11-10 07:44:06 +01:00
|
|
|
#include "shared/protobuf_util.h"
|
2022-12-05 09:58:23 -08:00
|
|
|
#include "shared/piscsi_exceptions.h"
|
|
|
|
#include "generated/piscsi_interface.pb.h"
|
|
|
|
#include "scsictl/scsictl_commands.h"
|
2022-10-23 21:51:39 +02:00
|
|
|
|
|
|
|
using namespace testing;
|
2022-12-05 09:58:23 -08:00
|
|
|
using namespace piscsi_interface;
|
2022-10-23 21:51:39 +02:00
|
|
|
using namespace protobuf_util;
|
|
|
|
|
2022-12-05 09:58:23 -08:00
|
|
|
TEST(ScsictlCommandsTest, Execute)
|
2022-10-23 21:51:39 +02:00
|
|
|
{
|
|
|
|
PbCommand command;
|
2022-12-05 09:58:23 -08:00
|
|
|
ScsictlCommands commands(command, "localhost", 0);
|
2022-10-23 21:51:39 +02:00
|
|
|
|
|
|
|
command.set_operation(LOG_LEVEL);
|
|
|
|
EXPECT_THROW(commands.Execute("log_level", "", "", "", ""), io_exception);
|
|
|
|
EXPECT_EQ("log_level", GetParam(command, "level"));
|
|
|
|
|
|
|
|
command.set_operation(DEFAULT_FOLDER);
|
|
|
|
EXPECT_THROW(commands.Execute("", "default_folder", "", "", ""), io_exception);
|
|
|
|
EXPECT_EQ("default_folder", GetParam(command, "folder"));
|
|
|
|
|
|
|
|
command.set_operation(RESERVE_IDS);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "reserved_ids", "", ""), io_exception);
|
|
|
|
EXPECT_EQ("reserved_ids", GetParam(command, "ids"));
|
|
|
|
|
|
|
|
command.set_operation(CREATE_IMAGE);
|
|
|
|
EXPECT_FALSE(commands.Execute("", "", "", "", ""));
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "filename:0", ""), io_exception);
|
|
|
|
EXPECT_EQ("false", GetParam(command, "read_only"));
|
|
|
|
|
|
|
|
command.set_operation(DELETE_IMAGE);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "filename1", ""), io_exception);
|
|
|
|
EXPECT_EQ("filename1", GetParam(command, "file"));
|
|
|
|
|
|
|
|
command.set_operation(RENAME_IMAGE);
|
|
|
|
EXPECT_FALSE(commands.Execute("", "", "", "", ""));
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "from1:to1", ""), io_exception);
|
|
|
|
EXPECT_EQ("from1", GetParam(command, "from"));
|
|
|
|
EXPECT_EQ("to1", GetParam(command, "to"));
|
|
|
|
|
|
|
|
command.set_operation(COPY_IMAGE);
|
|
|
|
EXPECT_FALSE(commands.Execute("", "", "", "", ""));
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "from2:to2", ""), io_exception);
|
|
|
|
EXPECT_EQ("from2", GetParam(command, "from"));
|
|
|
|
EXPECT_EQ("to2", GetParam(command, "to"));
|
|
|
|
|
|
|
|
command.set_operation(DEVICES_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(DEVICE_TYPES_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(VERSION_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(SERVER_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(DEFAULT_IMAGE_FILES_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(IMAGE_FILE_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", "filename2"), io_exception);
|
|
|
|
EXPECT_EQ("filename2", GetParam(command, "file"));
|
|
|
|
|
|
|
|
command.set_operation(NETWORK_INTERFACES_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(LOG_LEVEL_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(RESERVED_IDS_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(MAPPING_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
|
|
|
command.set_operation(OPERATION_INFO);
|
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
|
|
|
|
2023-10-15 08:38:15 +02:00
|
|
|
command.set_operation(DETACH_ALL);
|
2022-10-23 21:51:39 +02:00
|
|
|
EXPECT_THROW(commands.Execute("", "", "", "", ""), io_exception);
|
2023-10-15 08:38:15 +02:00
|
|
|
|
|
|
|
command.set_operation(NO_OPERATION);
|
|
|
|
EXPECT_FALSE(commands.Execute("", "", "", "", ""));
|
2022-10-23 21:51:39 +02:00
|
|
|
}
|
|
|
|
|
2022-12-05 09:58:23 -08:00
|
|
|
TEST(ScsictlCommandsTest, CommandDevicesInfo)
|
2022-10-23 21:51:39 +02:00
|
|
|
{
|
|
|
|
PbCommand command;
|
|
|
|
|
2022-12-05 09:58:23 -08:00
|
|
|
ScsictlCommands commands1(command, "/invalid_host_name", 0);
|
2022-10-23 21:51:39 +02:00
|
|
|
EXPECT_THROW(commands1.CommandDevicesInfo(), io_exception);
|
|
|
|
|
2022-12-05 09:58:23 -08:00
|
|
|
ScsictlCommands commands2(command, "localhost", 0);
|
2022-10-23 21:51:39 +02:00
|
|
|
EXPECT_THROW(commands2.CommandDevicesInfo(), io_exception);
|
|
|
|
}
|