blob: b57d988a50ef18be97636cd2dc7ef1c253e6f8be [file] [log] [blame]
sbarbari17d7e222019-11-05 10:02:29 -05001/*
2 * Copyright 2018-present Open Networking Foundation
3
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7
8 * http://www.apache.org/licenses/LICENSE-2.0
9
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package model
17
18import (
serkant.uluderya2ae470f2020-01-21 11:13:09 -080019 "github.com/opencord/voltha-protos/v3/go/voltha"
sbarbari17d7e222019-11-05 10:02:29 -050020 "reflect"
21 "testing"
22)
23
24// Dissect a proto message by extracting all the children fields
25func TestChildType_01_Device_Proto_ChildrenFields(t *testing.T) {
26 var cls *voltha.Device
27
28 t.Logf("Extracting children fields from proto type: %s", reflect.TypeOf(cls))
29 names := ChildrenFields(cls)
30 t.Logf("Extracting children field names: %+v", names)
31
32 expectedKeys := []string{"ports", "flows", "flow_groups", "image_downloads", "pm_configs"}
33 for _, key := range expectedKeys {
34 if _, exists := names[key]; !exists {
35 t.Errorf("Missing key:%s from class type:%s", key, reflect.TypeOf(cls))
36 }
37 }
38}
39
40// Verify that the cache contains an entry for types on which ChildrenFields was performed
41func TestChildType_02_Cache_Keys(t *testing.T) {
Kent Hagermana71a54d2020-03-09 12:30:23 -040042 childTypes.mutex.RLock()
43 defer childTypes.mutex.RUnlock()
44
45 if _, exists := childTypes.cache[reflect.TypeOf(&voltha.Device{})]; !exists {
46 t.Errorf("childTypes.cache should have an entry of type: %+v\n", reflect.TypeOf(&voltha.Device{}).String())
sbarbari17d7e222019-11-05 10:02:29 -050047 }
Kent Hagermana71a54d2020-03-09 12:30:23 -040048 for k := range childTypes.cache {
49 t.Logf("childTypes.cache Key:%+v\n", k)
sbarbari17d7e222019-11-05 10:02:29 -050050 }
51}