Merge pull request #110688 from jsafrane/test-iscsi
Fix iSCSI over ipv6
This commit is contained in:
		| @@ -406,10 +406,16 @@ func (util *ISCSIUtil) AttachDisk(b iscsiDiskMounter) (string, error) { | ||||
| 				klog.Errorf("iscsi: could not find transport name in iface %s", b.Iface) | ||||
| 				return "", fmt.Errorf("could not parse iface file for %s", b.Iface) | ||||
| 			} | ||||
|  | ||||
| 			addr := tp | ||||
| 			if strings.HasPrefix(tp, "[") { | ||||
| 				// Delete [] from IP address, links in /dev/disk/by-path do not have it. | ||||
| 				addr = strings.NewReplacer("[", "", "]", "").Replace(tp) | ||||
| 			} | ||||
| 			if iscsiTransport == "tcp" { | ||||
| 				devicePath = strings.Join([]string{"/dev/disk/by-path/ip", tp, "iscsi", b.Iqn, "lun", b.Lun}, "-") | ||||
| 				devicePath = strings.Join([]string{"/dev/disk/by-path/ip", addr, "iscsi", b.Iqn, "lun", b.Lun}, "-") | ||||
| 			} else { | ||||
| 				devicePath = strings.Join([]string{"/dev/disk/by-path/pci", "*", "ip", tp, "iscsi", b.Iqn, "lun", b.Lun}, "-") | ||||
| 				devicePath = strings.Join([]string{"/dev/disk/by-path/pci", "*", "ip", addr, "iscsi", b.Iqn, "lun", b.Lun}, "-") | ||||
| 			} | ||||
|  | ||||
| 			if exist := waitForPathToExist(&devicePath, deviceDiscoveryTimeout, iscsiTransport); !exist { | ||||
|   | ||||
| @@ -68,6 +68,11 @@ func TestExtractPortalAndIqn(t *testing.T) { | ||||
| 	if err != nil || portal != "127.0.0.1:3260" || iqn != "eui.02004567A425678D" { | ||||
| 		t.Errorf("extractPortalAndIqn: got %v %s %s", err, portal, iqn) | ||||
| 	} | ||||
| 	devicePath = "[2001:db8:0:f101::1]:3260-iqn.2014-12.com.example:test.tgt00-lun-0" | ||||
| 	portal, iqn, err = extractPortalAndIqn(devicePath) | ||||
| 	if err != nil || portal != "[2001:db8:0:f101::1]:3260" || iqn != "iqn.2014-12.com.example:test.tgt00" { | ||||
| 		t.Errorf("extractPortalAndIqn: got %v %s %s", err, portal, iqn) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestRemoveDuplicate(t *testing.T) { | ||||
|   | ||||
| @@ -22,6 +22,7 @@ package util | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"net" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"strconv" | ||||
| @@ -200,12 +201,11 @@ func (handler *deviceHandler) GetISCSIPortalHostMapForTarget(targetIqn string) ( | ||||
|  | ||||
| 				// Add entries to the map for both the current and persistent portals | ||||
| 				// pointing to the SCSI host for those connections | ||||
| 				portal := strings.TrimSpace(string(addr)) + ":" + | ||||
| 					strings.TrimSpace(string(port)) | ||||
| 				// JoinHostPort will add `[]` around IPv6 addresses. | ||||
| 				portal := net.JoinHostPort(strings.TrimSpace(string(addr)), strings.TrimSpace(string(port))) | ||||
| 				portalHostMap[portal] = hostNumber | ||||
|  | ||||
| 				persistentPortal := strings.TrimSpace(string(persistentAddr)) + ":" + | ||||
| 					strings.TrimSpace(string(persistentPort)) | ||||
| 				persistentPortal := net.JoinHostPort(strings.TrimSpace(string(persistentAddr)), strings.TrimSpace(string(persistentPort))) | ||||
| 				portalHostMap[persistentPortal] = hostNumber | ||||
| 			} | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot