Skip to content

Commit

Permalink
vcsim: Re-enable TenantManager
Browse files Browse the repository at this point in the history
* Tests were skipped to support older clients (<6.9).  Since supported
  clients have support for TenantManager, unskipped the test and removed
  the OldClients test.
  • Loading branch information
fdawg4l committed Jun 27, 2024
1 parent c1d0832 commit 65a221e
Show file tree
Hide file tree
Showing 3 changed files with 2 additions and 65 deletions.
2 changes: 1 addition & 1 deletion simulator/model.go
Original file line number Diff line number Diff line change
Expand Up @@ -264,7 +264,7 @@ var kinds = map[string]reflect.Type{
"StoragePod": reflect.TypeOf((*StoragePod)(nil)).Elem(),
"StorageResourceManager": reflect.TypeOf((*StorageResourceManager)(nil)).Elem(),
"TaskManager": reflect.TypeOf((*TaskManager)(nil)).Elem(),
"TenantTenantManager": reflect.TypeOf((*TenantManager)(nil)).Elem(),
"TenantManager": reflect.TypeOf((*TenantManager)(nil)).Elem(),
"UserDirectory": reflect.TypeOf((*UserDirectory)(nil)).Elem(),
"VcenterVStorageObjectManager": reflect.TypeOf((*VcenterVStorageObjectManager)(nil)).Elem(),
"ViewManager": reflect.TypeOf((*ViewManager)(nil)).Elem(),
Expand Down
64 changes: 0 additions & 64 deletions simulator/tenant_manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,6 @@ import (

"github.com/vmware/govmomi"
"github.com/vmware/govmomi/object"
"github.com/vmware/govmomi/vim25"
"github.com/vmware/govmomi/vim25/soap"
"github.com/vmware/govmomi/vim25/types"
)

Expand All @@ -43,69 +41,7 @@ func sortMoRefSlice(a []types.ManagedObjectReference) {
})
}

func TestTenantManagerForOldClients(t *testing.T) {
// ServiceContent TenantManager field is not present in older (<6.9.1) vmodl
// (e.g. response to RetrieveServiceConent() API or propery collector on
// ServiceInstance object), this field should be set only if the client is newer.
// Currently TenantManager is not set in vpx simulator's ServiceContent, and
// would be added once simulator supports client vmodl versioning properly.
t.Skip("needs vmodl versioning")

ctx := context.Background()
m := VPX()
defer m.Remove()

err := m.Create()
if err != nil {
t.Fatal(err)
}

s := m.Service.NewServer()
defer s.Close()

// Ensure non-nil moref being returned for ServiceContent.TenantManger for newer vim version clients.
newSoapClient := soap.NewClient(s.URL, true)
newSoapClient.Version = "6.9.1"
newVimClient, err := vim25.NewClient(ctx, newSoapClient)
if err != nil {
t.Fatal(err)
}
if newVimClient.ServiceContent.TenantManager == nil {
t.Fatal("Expected retrieved ServiceContent.TenantManager to be non-nil")
}

// Ensure non-nil moref being returned for ServiceContent.TenantManger for default version used in vim25 client.
defaultSoapClient := soap.NewClient(s.URL, true)
// No version being set for soap client
defaultVimClient, err := vim25.NewClient(ctx, defaultSoapClient)
if err != nil {
t.Fatal(err)
}
if defaultVimClient.ServiceContent.TenantManager == nil {
t.Fatal("Expected retrieved ServiceContent.TenantManager to be non-nil")
}

// Ensure nil being returned for ServiceContent.TenantManger for older vim version clients.
oldSoapClient := soap.NewClient(s.URL, true)
oldSoapClient.Version = "6.5"
oldVimClient, err := vim25.NewClient(ctx, oldSoapClient)
if err != nil {
t.Fatal(err)
}
if oldVimClient.ServiceContent.TenantManager != nil {
t.Fatalf("Expected retrieved ServiceContent.TenantManager to be nil but found %v", oldVimClient.ServiceContent.TenantManager)
}

}

func TestTenantManagerVPX(t *testing.T) {
// ServiceContent TenantManager field is not present in older (<6.9.1) vmodl
// (e.g. response to RetrieveServiceConent() API or propery collector on
// ServiceInstance object), this field should be set only if the client is newer.
// Currently TenantManager is not set in vpx simulator's ServiceContent, and
// would be added once simulator supports client vmodl versioning properly.
t.Skip("needs vmodl versioning")

ctx := context.Background()
m := VPX()
defer m.Remove()
Expand Down
1 change: 1 addition & 0 deletions simulator/vpx/service_content.go
Original file line number Diff line number Diff line change
Expand Up @@ -87,4 +87,5 @@ var ServiceContent = types.ServiceContent{
HealthUpdateManager: &types.ManagedObjectReference{Type: "HealthUpdateManager", Value: "HealthUpdateManager"},
FailoverClusterConfigurator: &types.ManagedObjectReference{Type: "FailoverClusterConfigurator", Value: "FailoverClusterConfigurator"},
FailoverClusterManager: &types.ManagedObjectReference{Type: "FailoverClusterManager", Value: "FailoverClusterManager"},
TenantManager: &types.ManagedObjectReference{Type: "TenantManager", Value: "TenantManager"},
}

0 comments on commit 65a221e

Please sign in to comment.