github.com/google/osv-scalibr@v0.4.1/extractor/filesystem/os/pacman/metadata/metadata_test.go (about) 1 // Copyright 2025 Google LLC 2 // 3 // Licensed under the Apache License, Version 2.0 (the "License"); 4 // you may not use this file except in compliance with the License. 5 // You may obtain a copy of the License at 6 // 7 // http://www.apache.org/licenses/LICENSE-2.0 8 // 9 // Unless required by applicable law or agreed to in writing, software 10 // distributed under the License is distributed on an "AS IS" BASIS, 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 // See the License for the specific language governing permissions and 13 // limitations under the License. 14 15 package metadata_test 16 17 import ( 18 "testing" 19 20 "github.com/google/go-cmp/cmp" 21 "github.com/google/osv-scalibr/extractor/filesystem/os/pacman/metadata" 22 "google.golang.org/protobuf/proto" 23 "google.golang.org/protobuf/testing/protocmp" 24 25 pb "github.com/google/osv-scalibr/binary/proto/scan_result_go_proto" 26 ) 27 28 func TestSetProto(t *testing.T) { 29 testCases := []struct { 30 desc string 31 m *metadata.Metadata 32 p *pb.Package 33 want *pb.Package 34 }{ 35 { 36 desc: "nil_metadata", 37 m: nil, 38 p: &pb.Package{Name: "some-package"}, 39 want: &pb.Package{Name: "some-package"}, 40 }, 41 { 42 desc: "nil_package", 43 m: &metadata.Metadata{ 44 PackageName: "name", 45 }, 46 p: nil, 47 want: nil, 48 }, 49 { 50 desc: "set_metadata", 51 m: &metadata.Metadata{ 52 PackageName: "name", 53 }, 54 p: &pb.Package{Name: "some-package"}, 55 want: &pb.Package{ 56 Name: "some-package", 57 Metadata: &pb.Package_PacmanMetadata{ 58 PacmanMetadata: &pb.PACMANPackageMetadata{ 59 PackageName: "name", 60 }, 61 }, 62 }, 63 }, 64 { 65 desc: "override_metadata", 66 m: &metadata.Metadata{ 67 PackageName: "another-name", 68 }, 69 p: &pb.Package{ 70 Name: "some-package", 71 Metadata: &pb.Package_PacmanMetadata{ 72 PacmanMetadata: &pb.PACMANPackageMetadata{ 73 PackageName: "name", 74 }, 75 }, 76 }, 77 want: &pb.Package{ 78 Name: "some-package", 79 Metadata: &pb.Package_PacmanMetadata{ 80 PacmanMetadata: &pb.PACMANPackageMetadata{ 81 PackageName: "another-name", 82 }, 83 }, 84 }, 85 }, 86 { 87 desc: "set_all_fields", 88 m: &metadata.Metadata{ 89 PackageName: "name", 90 PackageVersion: "version", 91 OSID: "os-id", 92 OSVersionID: "os-version-id", 93 PackageDependencies: "package-dependencies", 94 }, 95 p: &pb.Package{Name: "some-package"}, 96 want: &pb.Package{ 97 Name: "some-package", 98 Metadata: &pb.Package_PacmanMetadata{ 99 PacmanMetadata: &pb.PACMANPackageMetadata{ 100 PackageName: "name", 101 PackageVersion: "version", 102 OsId: "os-id", 103 OsVersionId: "os-version-id", 104 PackageDependencies: "package-dependencies", 105 }, 106 }, 107 }, 108 }, 109 } 110 111 for _, tc := range testCases { 112 t.Run(tc.desc, func(t *testing.T) { 113 p := proto.Clone(tc.p).(*pb.Package) 114 tc.m.SetProto(p) 115 opts := []cmp.Option{ 116 protocmp.Transform(), 117 } 118 if diff := cmp.Diff(tc.want, p, opts...); diff != "" { 119 t.Errorf("Metatadata{%+v}.SetProto(%+v): (-want +got):\n%s", tc.m, tc.p, diff) 120 } 121 122 // Test the reverse conversion for completeness. 123 124 if tc.p == nil && tc.want == nil { 125 return 126 } 127 128 got := metadata.ToStruct(p.GetPacmanMetadata()) 129 if diff := cmp.Diff(tc.m, got); diff != "" { 130 t.Errorf("ToStruct(%+v): (-want +got):\n%s", p.GetPacmanMetadata(), diff) 131 } 132 }) 133 } 134 } 135 136 func TestToStruct(t *testing.T) { 137 testCases := []struct { 138 desc string 139 m *pb.PACMANPackageMetadata 140 want *metadata.Metadata 141 }{ 142 { 143 desc: "nil", 144 m: nil, 145 want: nil, 146 }, 147 { 148 desc: "some_fields", 149 m: &pb.PACMANPackageMetadata{ 150 PackageName: "name", 151 }, 152 want: &metadata.Metadata{ 153 PackageName: "name", 154 }, 155 }, 156 { 157 desc: "all_fields", 158 m: &pb.PACMANPackageMetadata{ 159 PackageName: "name", 160 PackageVersion: "version", 161 OsId: "os-id", 162 OsVersionId: "os-version-id", 163 PackageDependencies: "package-dependencies", 164 }, 165 want: &metadata.Metadata{ 166 PackageName: "name", 167 PackageVersion: "version", 168 OSID: "os-id", 169 OSVersionID: "os-version-id", 170 PackageDependencies: "package-dependencies", 171 }, 172 }, 173 } 174 175 for _, tc := range testCases { 176 t.Run(tc.desc, func(t *testing.T) { 177 got := metadata.ToStruct(tc.m) 178 if diff := cmp.Diff(tc.want, got); diff != "" { 179 t.Errorf("ToStruct(%+v): (-want +got):\n%s", tc.m, diff) 180 } 181 182 if tc.m == nil { 183 return 184 } 185 186 // Test the reverse conversion for completeness. 187 188 gotP := &pb.Package{} 189 wantP := &pb.Package{ 190 Metadata: &pb.Package_PacmanMetadata{ 191 PacmanMetadata: tc.m, 192 }, 193 } 194 got.SetProto(gotP) 195 opts := []cmp.Option{ 196 protocmp.Transform(), 197 } 198 if diff := cmp.Diff(wantP, gotP, opts...); diff != "" { 199 t.Errorf("Metatadata{%+v}.SetProto(%+v): (-want +got):\n%s", got, wantP, diff) 200 } 201 }) 202 } 203 }