/* Copyright (C) 2013 Ronnie Sahlberg This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, see . */ #include #include #include #include #include "iscsi.h" #include "scsi-lowlevel.h" #include "iscsi-test-cu.h" void test_startstopunit_noloej(void) { logging(LOG_VERBOSE, LOG_BLANK_LINE); logging(LOG_VERBOSE, "Test STARTSTOPUNIT LOEJ==0"); if (!inq->rmb) { logging(LOG_VERBOSE, "[SKIPPED] LUN is not removable. " "Skipping test."); return; } logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==0 NO_FLUSH==0 START==0"); STARTSTOPUNIT(sd, 0, 0, 0, 0, 0, 0, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==0 NO_FLUSH==0 START==1"); STARTSTOPUNIT(sd, 0, 0, 0, 0, 0, 1, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==1 NO_FLUSH==0 START==0"); STARTSTOPUNIT(sd, 1, 0, 0, 0, 0, 0, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==1 NO_FLUSH==0 START==1"); STARTSTOPUNIT(sd, 1, 0, 0, 0, 0, 1, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==0 NO_FLUSH==1 START==0"); STARTSTOPUNIT(sd, 0, 0, 0, 1, 0, 0, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==0 NO_FLUSH==1 START==1"); STARTSTOPUNIT(sd, 0, 0, 0, 1, 0, 1, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==1 NO_FLUSH==1 START==0"); STARTSTOPUNIT(sd, 1, 0, 0, 1, 0, 0, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test that media is not ejected when LOEJ==0 IMMED==1 NO_FLUSH==1 START==1"); STARTSTOPUNIT(sd, 1, 0, 0, 1, 0, 1, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "Test TESTUNITREADY that medium is not ejected."); TESTUNITREADY(sd, EXPECT_STATUS_GOOD); logging(LOG_VERBOSE, "In case the target did eject the medium, load it again."); STARTSTOPUNIT(sd, 1, 0, 0, 0, 1, 1, EXPECT_STATUS_GOOD); }