2016-08-16 22:23:35 +00:00
|
|
|
/*-
|
|
|
|
* BSD LICENSE
|
|
|
|
*
|
|
|
|
* Copyright (c) Intel Corporation.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
* * Neither the name of Intel Corporation nor the names of its
|
|
|
|
* contributors may be used to endorse or promote products derived
|
|
|
|
* from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
2017-05-02 18:18:25 +00:00
|
|
|
#include "spdk/stdinc.h"
|
2016-08-16 22:23:35 +00:00
|
|
|
|
|
|
|
#include "spdk/scsi.h"
|
|
|
|
|
|
|
|
#include "CUnit/Basic.h"
|
|
|
|
|
|
|
|
#include "../common.c"
|
|
|
|
#include "iscsi/tgt_node.c"
|
2017-05-02 17:56:08 +00:00
|
|
|
#include "scsi/scsi_internal.h"
|
2016-08-16 22:23:35 +00:00
|
|
|
|
2017-01-19 17:16:31 +00:00
|
|
|
struct spdk_iscsi_globals g_spdk_iscsi;
|
|
|
|
|
2016-08-16 22:23:35 +00:00
|
|
|
const char *config_file;
|
|
|
|
|
|
|
|
bool
|
|
|
|
spdk_sock_is_ipv6(int sock)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
spdk_sock_is_ipv4(int sock)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct spdk_iscsi_portal_grp *
|
|
|
|
spdk_iscsi_portal_grp_find_by_tag(int tag)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-10-10 01:08:42 +00:00
|
|
|
struct spdk_iscsi_init_grp *
|
|
|
|
spdk_iscsi_init_grp_find_by_tag(int tag)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-05-02 17:56:08 +00:00
|
|
|
struct spdk_scsi_lun *
|
|
|
|
spdk_scsi_dev_get_lun(struct spdk_scsi_dev *dev, int lun_id)
|
|
|
|
{
|
2017-07-05 13:10:30 +00:00
|
|
|
if (lun_id < 0 || lun_id >= SPDK_SCSI_DEV_MAX_LUN) {
|
2017-05-02 17:56:08 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return dev->lun[lun_id];
|
|
|
|
}
|
|
|
|
|
2016-08-16 22:23:35 +00:00
|
|
|
static void
|
|
|
|
config_file_fail_cases(void)
|
|
|
|
{
|
|
|
|
struct spdk_conf *config;
|
|
|
|
struct spdk_conf_section *sp;
|
|
|
|
char section_name[64];
|
|
|
|
int section_index;
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
config = spdk_conf_allocate();
|
|
|
|
|
|
|
|
rc = spdk_conf_read(config, config_file);
|
|
|
|
CU_ASSERT(rc == 0);
|
|
|
|
|
|
|
|
section_index = 0;
|
|
|
|
while (true) {
|
2017-03-23 07:44:36 +00:00
|
|
|
snprintf(section_name, sizeof(section_name), "Failure%d", section_index);
|
2016-08-16 22:23:35 +00:00
|
|
|
sp = spdk_conf_find_section(config, section_name);
|
|
|
|
if (sp == NULL) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
rc = spdk_cf_add_iscsi_tgt_node(sp);
|
|
|
|
CU_ASSERT(rc < 0);
|
|
|
|
section_index++;
|
|
|
|
}
|
2017-03-29 20:54:20 +00:00
|
|
|
|
|
|
|
spdk_conf_free(config);
|
2016-08-16 22:23:35 +00:00
|
|
|
}
|
|
|
|
|
2017-10-24 01:20:09 +00:00
|
|
|
static void
|
|
|
|
allow_ipv6_allowed(void)
|
|
|
|
{
|
2017-11-13 02:14:02 +00:00
|
|
|
bool result;
|
2017-10-24 01:20:09 +00:00
|
|
|
char *netmask;
|
|
|
|
char *addr;
|
|
|
|
|
|
|
|
netmask = "[2001:ad6:1234::]/48";
|
|
|
|
addr = "2001:ad6:1234:5678:9abc::";
|
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_ipv6_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == true);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == true);
|
2017-10-24 01:20:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
allow_ipv6_denied(void)
|
|
|
|
{
|
2017-11-13 02:14:02 +00:00
|
|
|
bool result;
|
2017-10-24 01:20:09 +00:00
|
|
|
char *netmask;
|
|
|
|
char *addr;
|
|
|
|
|
|
|
|
netmask = "[2001:ad6:1234::]/56";
|
|
|
|
addr = "2001:ad6:1234:5678:9abc::";
|
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_ipv6_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == false);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == false);
|
2017-10-24 01:20:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
allow_ipv4_allowed(void)
|
|
|
|
{
|
2017-11-13 02:14:02 +00:00
|
|
|
bool result;
|
2017-10-24 01:20:09 +00:00
|
|
|
char *netmask;
|
|
|
|
char *addr;
|
|
|
|
|
|
|
|
netmask = "192.168.2.0/24";
|
|
|
|
addr = "192.168.2.1";
|
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_ipv4_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == true);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == true);
|
2017-10-24 01:20:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
allow_ipv4_denied(void)
|
|
|
|
{
|
2017-11-13 02:14:02 +00:00
|
|
|
bool result;
|
2017-10-24 01:20:09 +00:00
|
|
|
char *netmask;
|
|
|
|
char *addr;
|
|
|
|
|
|
|
|
netmask = "192.168.2.0";
|
|
|
|
addr = "192.168.2.1";
|
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_ipv4_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == false);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
2017-11-29 06:08:38 +00:00
|
|
|
result = spdk_iscsi_netmask_allow_addr(netmask, addr);
|
2017-11-13 02:14:02 +00:00
|
|
|
CU_ASSERT(result == false);
|
2017-10-24 01:20:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
node_access_allowed(void)
|
|
|
|
{
|
|
|
|
struct spdk_iscsi_tgt_node tgtnode;
|
|
|
|
struct spdk_iscsi_portal_grp pg;
|
|
|
|
struct spdk_iscsi_init_grp ig;
|
|
|
|
struct spdk_iscsi_conn conn;
|
|
|
|
struct spdk_iscsi_portal portal;
|
2017-11-15 00:14:27 +00:00
|
|
|
struct spdk_iscsi_initiator_name iname;
|
|
|
|
struct spdk_iscsi_initiator_netmask imask;
|
2017-12-05 06:42:37 +00:00
|
|
|
struct spdk_scsi_dev scsi_dev;
|
2017-11-30 01:43:01 +00:00
|
|
|
struct spdk_iscsi_pg_map *pg_map;
|
2017-10-24 01:20:09 +00:00
|
|
|
char *iqn, *addr;
|
2017-11-13 02:14:02 +00:00
|
|
|
bool result;
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
/* portal group initialization */
|
|
|
|
memset(&pg, 0, sizeof(struct spdk_iscsi_portal_grp));
|
|
|
|
pg.tag = 1;
|
|
|
|
|
|
|
|
/* initiator group initialization */
|
|
|
|
memset(&ig, 0, sizeof(struct spdk_iscsi_init_grp));
|
|
|
|
ig.tag = 1;
|
|
|
|
|
|
|
|
ig.ninitiators = 1;
|
2017-11-15 00:14:27 +00:00
|
|
|
iname.name = "iqn.2017-10.spdk.io:0001";
|
|
|
|
TAILQ_INIT(&ig.initiator_head);
|
|
|
|
TAILQ_INSERT_TAIL(&ig.initiator_head, &iname, tailq);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
ig.nnetmasks = 1;
|
2017-11-15 00:14:27 +00:00
|
|
|
imask.mask = "192.168.2.0/24";
|
|
|
|
TAILQ_INIT(&ig.netmask_head);
|
|
|
|
TAILQ_INSERT_TAIL(&ig.netmask_head, &imask, tailq);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
/* target initialization */
|
|
|
|
memset(&tgtnode, 0, sizeof(struct spdk_iscsi_tgt_node));
|
|
|
|
tgtnode.name = "iqn.2017-10.spdk.io:0001";
|
2017-11-30 01:43:01 +00:00
|
|
|
TAILQ_INIT(&tgtnode.pg_map_head);
|
2017-12-05 06:42:37 +00:00
|
|
|
|
|
|
|
memset(&scsi_dev, 0, sizeof(struct spdk_scsi_dev));
|
|
|
|
strncpy(scsi_dev.name, "iqn.2017-10.spdk.io:0001", SPDK_SCSI_DEV_MAX_NAME);
|
|
|
|
tgtnode.dev = &scsi_dev;
|
|
|
|
|
2017-11-30 01:43:01 +00:00
|
|
|
pg_map = spdk_iscsi_tgt_node_add_pg_map(&tgtnode, &pg);
|
|
|
|
spdk_iscsi_pg_map_add_ig_map(pg_map, &ig);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
/* portal initialization */
|
|
|
|
memset(&portal, 0, sizeof(struct spdk_iscsi_portal));
|
|
|
|
portal.group = &pg;
|
|
|
|
portal.host = "192.168.2.0";
|
|
|
|
portal.port = "3260";
|
|
|
|
|
|
|
|
/* input for UT */
|
|
|
|
memset(&conn, 0, sizeof(struct spdk_iscsi_conn));
|
|
|
|
conn.portal = &portal;
|
|
|
|
|
|
|
|
iqn = "iqn.2017-10.spdk.io:0001";
|
|
|
|
addr = "192.168.2.1";
|
|
|
|
|
2017-11-13 02:14:02 +00:00
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == true);
|
2017-11-30 01:43:01 +00:00
|
|
|
|
|
|
|
spdk_iscsi_pg_map_delete_ig_map(pg_map, &ig);
|
|
|
|
spdk_iscsi_tgt_node_delete_pg_map(&tgtnode, &pg);
|
2017-10-24 01:20:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
node_access_denied_by_empty_netmask(void)
|
|
|
|
{
|
|
|
|
struct spdk_iscsi_tgt_node tgtnode;
|
|
|
|
struct spdk_iscsi_portal_grp pg;
|
|
|
|
struct spdk_iscsi_init_grp ig;
|
|
|
|
struct spdk_iscsi_conn conn;
|
|
|
|
struct spdk_iscsi_portal portal;
|
2017-11-15 00:14:27 +00:00
|
|
|
struct spdk_iscsi_initiator_name iname;
|
2017-12-05 06:42:37 +00:00
|
|
|
struct spdk_scsi_dev scsi_dev;
|
2017-11-30 01:43:01 +00:00
|
|
|
struct spdk_iscsi_pg_map *pg_map;
|
2017-10-24 01:20:09 +00:00
|
|
|
char *iqn, *addr;
|
2017-11-13 02:14:02 +00:00
|
|
|
bool result;
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
/* portal group initialization */
|
|
|
|
memset(&pg, 0, sizeof(struct spdk_iscsi_portal_grp));
|
|
|
|
pg.tag = 1;
|
|
|
|
|
|
|
|
/* initiator group initialization */
|
|
|
|
memset(&ig, 0, sizeof(struct spdk_iscsi_init_grp));
|
|
|
|
ig.tag = 1;
|
|
|
|
|
|
|
|
ig.ninitiators = 1;
|
2017-11-15 00:14:27 +00:00
|
|
|
iname.name = "iqn.2017-10.spdk.io:0001";
|
|
|
|
TAILQ_INIT(&ig.initiator_head);
|
|
|
|
TAILQ_INSERT_TAIL(&ig.initiator_head, &iname, tailq);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
ig.nnetmasks = 0;
|
2017-11-15 00:14:27 +00:00
|
|
|
TAILQ_INIT(&ig.netmask_head);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
/* target initialization */
|
|
|
|
memset(&tgtnode, 0, sizeof(struct spdk_iscsi_tgt_node));
|
|
|
|
tgtnode.name = "iqn.2017-10.spdk.io:0001";
|
2017-11-30 01:43:01 +00:00
|
|
|
TAILQ_INIT(&tgtnode.pg_map_head);
|
2017-12-05 06:42:37 +00:00
|
|
|
|
|
|
|
memset(&scsi_dev, 0, sizeof(struct spdk_scsi_dev));
|
|
|
|
strncpy(scsi_dev.name, "iqn.2017-10.spdk.io:0001", SPDK_SCSI_DEV_MAX_NAME);
|
|
|
|
tgtnode.dev = &scsi_dev;
|
|
|
|
|
2017-11-30 01:43:01 +00:00
|
|
|
pg_map = spdk_iscsi_tgt_node_add_pg_map(&tgtnode, &pg);
|
|
|
|
spdk_iscsi_pg_map_add_ig_map(pg_map, &ig);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
|
|
|
/* portal initialization */
|
|
|
|
memset(&portal, 0, sizeof(struct spdk_iscsi_portal));
|
|
|
|
portal.group = &pg;
|
|
|
|
portal.host = "192.168.2.0";
|
|
|
|
portal.port = "3260";
|
|
|
|
|
|
|
|
/* input for UT */
|
|
|
|
memset(&conn, 0, sizeof(struct spdk_iscsi_conn));
|
|
|
|
conn.portal = &portal;
|
|
|
|
|
|
|
|
iqn = "iqn.2017-10.spdk.io:0001";
|
|
|
|
addr = "192.168.3.1";
|
|
|
|
|
2017-11-13 02:14:02 +00:00
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
2017-10-24 01:20:09 +00:00
|
|
|
|
2017-11-30 01:43:01 +00:00
|
|
|
spdk_iscsi_pg_map_delete_ig_map(pg_map, &ig);
|
|
|
|
spdk_iscsi_tgt_node_delete_pg_map(&tgtnode, &pg);
|
2017-10-24 01:20:09 +00:00
|
|
|
}
|
|
|
|
|
2017-11-29 06:11:11 +00:00
|
|
|
#define IQN1 "iqn.2017-11.spdk.io:0001"
|
|
|
|
#define NO_IQN1 "!iqn.2017-11.spdk.io:0001"
|
|
|
|
#define IQN2 "iqn.2017-11.spdk.io:0002"
|
|
|
|
#define IP1 "192.168.2.0"
|
|
|
|
#define IP2 "192.168.2.1"
|
|
|
|
|
|
|
|
static void
|
|
|
|
node_access_multi_initiator_groups_cases(void)
|
|
|
|
{
|
|
|
|
struct spdk_iscsi_tgt_node tgtnode;
|
|
|
|
struct spdk_iscsi_conn conn;
|
|
|
|
struct spdk_iscsi_portal_grp pg;
|
|
|
|
struct spdk_iscsi_portal portal;
|
|
|
|
struct spdk_iscsi_init_grp ig1, ig2;
|
|
|
|
struct spdk_iscsi_initiator_name iname1, iname2;
|
|
|
|
struct spdk_iscsi_initiator_netmask imask1, imask2;
|
2017-12-05 06:42:37 +00:00
|
|
|
struct spdk_scsi_dev scsi_dev;
|
2017-11-30 01:43:01 +00:00
|
|
|
struct spdk_iscsi_pg_map *pg_map;
|
2017-11-29 06:11:11 +00:00
|
|
|
char *iqn, *addr;
|
|
|
|
bool result;
|
|
|
|
|
|
|
|
/* target initialization */
|
|
|
|
memset(&tgtnode, 0, sizeof(struct spdk_iscsi_tgt_node));
|
|
|
|
tgtnode.name = IQN1;
|
2017-11-30 01:43:01 +00:00
|
|
|
TAILQ_INIT(&tgtnode.pg_map_head);
|
2017-12-05 06:42:37 +00:00
|
|
|
|
|
|
|
memset(&scsi_dev, 0, sizeof(struct spdk_scsi_dev));
|
|
|
|
strncpy(scsi_dev.name, IQN1, SPDK_SCSI_DEV_MAX_NAME);
|
|
|
|
tgtnode.dev = &scsi_dev;
|
|
|
|
|
2017-11-30 01:43:01 +00:00
|
|
|
pg_map = spdk_iscsi_tgt_node_add_pg_map(&tgtnode, &pg);
|
|
|
|
spdk_iscsi_pg_map_add_ig_map(pg_map, &ig1);
|
|
|
|
spdk_iscsi_pg_map_add_ig_map(pg_map, &ig2);
|
2017-11-29 06:11:11 +00:00
|
|
|
|
|
|
|
/* portal group initialization */
|
|
|
|
memset(&pg, 0, sizeof(struct spdk_iscsi_portal_grp));
|
|
|
|
pg.tag = 1;
|
|
|
|
|
|
|
|
/* portal initialization */
|
|
|
|
memset(&portal, 0, sizeof(struct spdk_iscsi_portal));
|
|
|
|
portal.group = &pg;
|
|
|
|
portal.host = IP1;
|
|
|
|
portal.port = "3260";
|
|
|
|
|
|
|
|
/* connection initialization */
|
|
|
|
memset(&conn, 0, sizeof(struct spdk_iscsi_conn));
|
|
|
|
conn.portal = &portal;
|
|
|
|
|
|
|
|
/* initiator group initialization */
|
|
|
|
memset(&ig1, 0, sizeof(struct spdk_iscsi_init_grp));
|
|
|
|
ig1.tag = 1;
|
|
|
|
TAILQ_INIT(&ig1.initiator_head);
|
|
|
|
TAILQ_INIT(&ig1.netmask_head);
|
|
|
|
|
|
|
|
ig1.ninitiators = 1;
|
|
|
|
iname1.name = NULL;
|
|
|
|
TAILQ_INSERT_TAIL(&ig1.initiator_head, &iname1, tailq);
|
|
|
|
|
|
|
|
ig1.nnetmasks = 1;
|
|
|
|
imask1.mask = NULL;
|
|
|
|
TAILQ_INSERT_TAIL(&ig1.netmask_head, &imask1, tailq);
|
|
|
|
|
|
|
|
memset(&ig2, 0, sizeof(struct spdk_iscsi_init_grp));
|
|
|
|
ig2.tag = 2;
|
|
|
|
TAILQ_INIT(&ig2.initiator_head);
|
|
|
|
TAILQ_INIT(&ig2.netmask_head);
|
|
|
|
|
|
|
|
ig2.ninitiators = 1;
|
|
|
|
iname2.name = NULL;
|
|
|
|
TAILQ_INSERT_TAIL(&ig2.initiator_head, &iname2, tailq);
|
|
|
|
|
|
|
|
ig2.nnetmasks = 1;
|
|
|
|
imask2.mask = NULL;
|
|
|
|
TAILQ_INSERT_TAIL(&ig2.netmask_head, &imask2, tailq);
|
|
|
|
|
|
|
|
iqn = IQN1;
|
|
|
|
addr = IP1;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 1:
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +-------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | denied | - | - | - | denied |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = NO_IQN1;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 2:
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +-------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | allowed | allowed | - | - | allowed |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN1;
|
|
|
|
imask1.mask = IP1;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == true);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 3:
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +-------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | allowed | denied | denied | - | denied |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN1;
|
|
|
|
imask1.mask = IP2;
|
|
|
|
iname2.name = NO_IQN1;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 4:
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +-------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
* | allowed | denied | allowed | allowed | allowed |
|
|
|
|
* +-------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN1;
|
|
|
|
imask1.mask = IP2;
|
|
|
|
iname2.name = IQN1;
|
|
|
|
imask2.mask = IP1;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == true);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 5:
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +---------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | allowed | denied | allowed | denied | denied |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN1;
|
|
|
|
imask1.mask = IP2;
|
|
|
|
iname2.name = IQN1;
|
|
|
|
imask2.mask = IP2;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 6:
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +---------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | allowed | denied | not found | - | denied |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN1;
|
|
|
|
imask1.mask = IP2;
|
|
|
|
iname2.name = IQN2;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 7:
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +---------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | not found | - | denied | - | denied |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN2;
|
|
|
|
iname2.name = NO_IQN1;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 8:
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +---------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | not found | - | allowed | allowed | allowed |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN2;
|
|
|
|
iname2.name = IQN1;
|
|
|
|
imask2.mask = IP1;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == true);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 9:
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +---------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | not found | - | allowed | denied | denied |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN2;
|
|
|
|
iname2.name = IQN1;
|
|
|
|
imask2.mask = IP2;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* case 10:
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | IG1 | IG2 | |
|
|
|
|
* +---------------------------------------------+ |
|
|
|
|
* | name | addr | name | addr | result |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
* | not found | - | not found | - | denied |
|
|
|
|
* +---------------------------------------------+---------+
|
|
|
|
*/
|
|
|
|
iname1.name = IQN2;
|
|
|
|
iname2.name = IQN2;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_access(&conn, &tgtnode, iqn, addr);
|
|
|
|
CU_ASSERT(result == false);
|
2017-11-30 01:43:01 +00:00
|
|
|
|
|
|
|
spdk_iscsi_pg_map_delete_ig_map(pg_map, &ig1);
|
|
|
|
spdk_iscsi_pg_map_delete_ig_map(pg_map, &ig2);
|
|
|
|
spdk_iscsi_tgt_node_delete_pg_map(&tgtnode, &pg);
|
2017-11-29 06:11:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
allow_iscsi_name_multi_maps_case(void)
|
|
|
|
{
|
|
|
|
struct spdk_iscsi_tgt_node tgtnode;
|
2017-11-30 01:43:01 +00:00
|
|
|
struct spdk_iscsi_portal_grp pg1, pg2;
|
2017-11-29 06:11:11 +00:00
|
|
|
struct spdk_iscsi_init_grp ig;
|
|
|
|
struct spdk_iscsi_initiator_name iname;
|
2017-11-30 01:43:01 +00:00
|
|
|
struct spdk_iscsi_pg_map *pg_map1, *pg_map2;
|
2017-12-05 06:42:37 +00:00
|
|
|
struct spdk_scsi_dev scsi_dev;
|
2017-11-29 06:11:11 +00:00
|
|
|
char *iqn;
|
|
|
|
bool result;
|
|
|
|
|
|
|
|
/* target initialization */
|
|
|
|
memset(&tgtnode, 0, sizeof(struct spdk_iscsi_tgt_node));
|
2017-11-30 01:43:01 +00:00
|
|
|
TAILQ_INIT(&tgtnode.pg_map_head);
|
2017-12-05 06:42:37 +00:00
|
|
|
|
|
|
|
memset(&scsi_dev, 0, sizeof(struct spdk_scsi_dev));
|
|
|
|
strncpy(scsi_dev.name, IQN1, SPDK_SCSI_DEV_MAX_NAME);
|
|
|
|
tgtnode.dev = &scsi_dev;
|
|
|
|
|
2017-11-30 01:43:01 +00:00
|
|
|
pg_map1 = spdk_iscsi_tgt_node_add_pg_map(&tgtnode, &pg1);
|
|
|
|
pg_map2 = spdk_iscsi_tgt_node_add_pg_map(&tgtnode, &pg2);
|
|
|
|
spdk_iscsi_pg_map_add_ig_map(pg_map1, &ig);
|
|
|
|
spdk_iscsi_pg_map_add_ig_map(pg_map2, &ig);
|
2017-11-29 06:11:11 +00:00
|
|
|
|
|
|
|
/* initiator group initialization */
|
|
|
|
memset(&ig, 0, sizeof(struct spdk_iscsi_init_grp));
|
|
|
|
TAILQ_INIT(&ig.initiator_head);
|
|
|
|
|
|
|
|
ig.ninitiators = 1;
|
|
|
|
iname.name = NULL;
|
|
|
|
TAILQ_INSERT_TAIL(&ig.initiator_head, &iname, tailq);
|
|
|
|
|
|
|
|
/* test for IG1 <-> PG1, PG2 case */
|
|
|
|
iqn = IQN1;
|
|
|
|
|
|
|
|
iname.name = IQN1;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_allow_iscsi_name(&tgtnode, iqn);
|
|
|
|
CU_ASSERT(result == true);
|
|
|
|
|
|
|
|
iname.name = IQN2;
|
|
|
|
|
|
|
|
result = spdk_iscsi_tgt_node_allow_iscsi_name(&tgtnode, iqn);
|
|
|
|
CU_ASSERT(result == false);
|
|
|
|
|
2017-11-30 01:43:01 +00:00
|
|
|
spdk_iscsi_pg_map_delete_ig_map(pg_map1, &ig);
|
|
|
|
spdk_iscsi_pg_map_delete_ig_map(pg_map2, &ig);
|
|
|
|
spdk_iscsi_tgt_node_delete_pg_map(&tgtnode, &pg1);
|
|
|
|
spdk_iscsi_tgt_node_delete_pg_map(&tgtnode, &pg2);
|
|
|
|
}
|
2017-11-29 06:11:11 +00:00
|
|
|
|
2016-08-16 22:23:35 +00:00
|
|
|
int
|
|
|
|
main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
CU_pSuite suite = NULL;
|
|
|
|
unsigned int num_failures;
|
|
|
|
|
|
|
|
if (argc < 2) {
|
|
|
|
fprintf(stderr, "usage: %s <config file>\n", argv[0]);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (CU_initialize_registry() != CUE_SUCCESS) {
|
|
|
|
return CU_get_error();
|
|
|
|
}
|
|
|
|
|
|
|
|
config_file = argv[1];
|
|
|
|
|
|
|
|
suite = CU_add_suite("iscsi_target_node_suite", NULL, NULL);
|
|
|
|
if (suite == NULL) {
|
|
|
|
CU_cleanup_registry();
|
|
|
|
return CU_get_error();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (
|
|
|
|
CU_add_test(suite, "config file fail cases", config_file_fail_cases) == NULL
|
2017-10-24 01:20:09 +00:00
|
|
|
|| CU_add_test(suite, "allow ipv6 allowed case", allow_ipv6_allowed) == NULL
|
|
|
|
|| CU_add_test(suite, "allow ipv6 denied case", allow_ipv6_denied) == NULL
|
|
|
|
|| CU_add_test(suite, "allow ipv4 allowed case", allow_ipv4_allowed) == NULL
|
|
|
|
|| CU_add_test(suite, "allow ipv4 denied case", allow_ipv4_denied) == NULL
|
|
|
|
|| CU_add_test(suite, "node access allowed case", node_access_allowed) == NULL
|
|
|
|
|| CU_add_test(suite, "node access denied case (empty netmask)",
|
|
|
|
node_access_denied_by_empty_netmask) == NULL
|
2017-11-29 06:11:11 +00:00
|
|
|
|| CU_add_test(suite, "node access multiple initiator groups cases",
|
|
|
|
node_access_multi_initiator_groups_cases) == NULL
|
|
|
|
|| CU_add_test(suite, "allow iscsi name case",
|
|
|
|
allow_iscsi_name_multi_maps_case) == NULL
|
2016-08-16 22:23:35 +00:00
|
|
|
) {
|
|
|
|
CU_cleanup_registry();
|
|
|
|
return CU_get_error();
|
|
|
|
}
|
|
|
|
|
|
|
|
CU_basic_set_mode(CU_BRM_VERBOSE);
|
|
|
|
CU_basic_run_tests();
|
|
|
|
num_failures = CU_get_number_of_failures();
|
|
|
|
CU_cleanup_registry();
|
|
|
|
return num_failures;
|
|
|
|
}
|