vmware: Add portgroup_portkey and portgroup_key (#38958)

* VMware: apply correct value for datacenter in TC

Signed-off-by: Tim Steinbach <tim@nequissimus.com>
Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
pull/39148/head
Tim Steinbach 7 years ago committed by Abhijeet Kasurde
parent 7437d6fdc4
commit f61172e6c7

@ -103,7 +103,7 @@ def find_entity_child_by_path(content, entityRootFolder, path):
if entity.name == paths[-1]: if entity.name == paths[-1]:
return entity return entity
except: except BaseException:
pass pass
return None return None
@ -337,7 +337,7 @@ def gather_vm_facts(content, vm):
for item in vm.layout.disk: for item in vm.layout.disk:
for disk in item.diskFile: for disk in item.diskFile:
facts['hw_files'].append(disk) facts['hw_files'].append(disk)
except: except BaseException:
pass pass
facts['hw_folder'] = PyVmomi.get_vm_path(content, vm) facts['hw_folder'] = PyVmomi.get_vm_path(content, vm)
@ -380,6 +380,14 @@ def gather_vm_facts(content, vm):
else: else:
mac_addr = mac_addr_dash = None mac_addr = mac_addr_dash = None
if (hasattr(entry, 'backing') and hasattr(entry.backing, 'port') and
hasattr(entry.backing.port, 'portKey') and hasattr(entry.backing.port, 'portgroupKey')):
port_group_key = entry.backing.port.portgroupKey
port_key = entry.backing.port.portKey
else:
port_group_key = None
port_key = None
factname = 'hw_eth' + str(ethernet_idx) factname = 'hw_eth' + str(ethernet_idx)
facts[factname] = { facts[factname] = {
'addresstype': entry.addressType, 'addresstype': entry.addressType,
@ -388,6 +396,8 @@ def gather_vm_facts(content, vm):
'ipaddresses': net_dict.get(entry.macAddress, None), 'ipaddresses': net_dict.get(entry.macAddress, None),
'macaddress_dash': mac_addr_dash, 'macaddress_dash': mac_addr_dash,
'summary': entry.deviceInfo.summary, 'summary': entry.deviceInfo.summary,
'portgroup_portkey': port_key,
'portgroup_key': port_group_key,
} }
facts['hw_interfaces'].append('eth' + str(ethernet_idx)) facts['hw_interfaces'].append('eth' + str(ethernet_idx))
ethernet_idx += 1 ethernet_idx += 1
@ -1048,7 +1058,7 @@ class PyVmomi(object):
folder_name = fp.name + '/' + folder_name folder_name = fp.name + '/' + folder_name
try: try:
fp = fp.parent fp = fp.parent
except: except BaseException:
break break
folder_name = '/' + folder_name folder_name = '/' + folder_name
return folder_name return folder_name

@ -27,8 +27,10 @@
- include: delete_vm.yml - include: delete_vm.yml
- include: non_existent_vm_ops.yml - include: non_existent_vm_ops.yml
- include: network_negative_test.yml - include: network_negative_test.yml
# VCSIM does not return list of portgroups for dvswitch so commenting following TC
#- include: network_with_portgroup.yml
# Currently, VCSIM doesn't support DVPG (as portkeys are not available) so commenting this test # Currently, VCSIM doesn't support DVPG (as portkeys are not available) so commenting this test
#- include: network_with_dvpg.yml # - include: network_with_dvpg.yml
#- include: template_d1_c1_f0.yml #- include: template_d1_c1_f0.yml
- include: vapp_d1_c1_f0.yml - include: vapp_d1_c1_f0.yml
- include: disk_size_d1_c1_f0.yml - include: disk_size_d1_c1_f0.yml

@ -0,0 +1,96 @@
# Test code for the vmware_guest module.
# Copyright: (c) 2018, Abhijeet Kasurde <akasurde@redhat.com>, Tim Steinbach <tim@nequissimus.com>
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
- name: Wait for Flask controller to come up online
wait_for:
host: "{{ vcsim }}"
port: 5000
state: started
- name: kill vcsim
uri:
url: http://{{ vcsim }}:5000/killall
- name: start vcsim with no folders
uri:
url: http://{{ vcsim }}:5000/spawn?datacenter=1&cluster=1&folder=0
register: vcsim_instance
- name: Wait for Flask controller to come up online
wait_for:
host: "{{ vcsim }}"
port: 443
state: started
- name: get a list of VMS from vcsim
uri:
url: http://{{ vcsim }}:5000/govc_find?filter=VM
register: vmlist
- debug: var=vcsim_instance
- debug: var=vmlist
- set_fact:
vm1: "{{ vmlist['json'][0] }}"
- debug: var=vm1
- name: Create dvswitch
vmware_dvswitch:
validate_certs: False
hostname: "{{ vcsim }}"
username: "{{ vcsim_instance['json']['username'] }}"
password: "{{ vcsim_instance['json']['password'] }}"
datacenter_name: "{{ (vm1 | basename).split('_')[0] }}"
switch_name: dvSwitch
uplink_quantity: 2
discovery_proto: lldp
discovery_operation: both
mtu: 9000
state: present
register: dvswitch
- name: Add portgroup
vmware_dvs_portgroup:
validate_certs: False
hostname: "{{ vcsim }}"
username: "{{ vcsim_instance['json']['username'] }}"
password: "{{ vcsim_instance['json']['password'] }}"
portgroup_name: "portgroup_network"
switch_name: "{{ dvswitch.switch_name }}"
vlan_id: "1"
num_ports: 2
portgroup_type: earlyBinding
state: present
register: dvsportgroup
- name: create new VMs with portgroup
vmware_guest:
validate_certs: False
hostname: "{{ vcsim }}"
username: "{{ vcsim_instance['json']['username'] }}"
password: "{{ vcsim_instance['json']['password'] }}"
name: new_vm_pg
guest_id: centos64Guest
datacenter: "{{ (vm1 | basename).split('_')[0] }}"
disk:
- size: 3mb
type: thin
autoselect_datastore: yes
networks:
- name: "{{ dvsportgroup.portgroup_name }}"
hardware:
num_cpus: 1
memory_mb: 512
state: poweredoff
folder: "{{ vm1 | dirname }}"
register: vm_with_portgroup
ignore_errors: no
- debug: var=vm_with_portgroup
- assert:
that:
- "vm_with_portgroup.changed"

@ -83,6 +83,8 @@
- "guest_facts_0001['instance']['hw_folder'] is defined" - "guest_facts_0001['instance']['hw_folder'] is defined"
- "guest_facts_0001['instance']['guest_question'] is defined" - "guest_facts_0001['instance']['guest_question'] is defined"
- "guest_facts_0001['instance']['guest_consolidation_needed'] is defined" - "guest_facts_0001['instance']['guest_consolidation_needed'] is defined"
- "'portgroup_portkey' in guest_facts_0001['instance']['hw_eth0']"
- "'portgroup_key' in guest_facts_0001['instance']['hw_eth0']"
- set_fact: vm1_uuid="{{ guest_facts_0001['instance']['hw_product_uuid'] }}" - set_fact: vm1_uuid="{{ guest_facts_0001['instance']['hw_product_uuid'] }}"

Loading…
Cancel
Save