1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
# Copyright 2023 The Bazel Authors. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""PyInfo testing subject."""
load("@rules_testing//lib:truth.bzl", "subjects")
def py_info_subject(info, *, meta):
"""Creates a new `PyInfoSubject` for a PyInfo provider instance.
Method: PyInfoSubject.new
Args:
info: The PyInfo object
meta: ExpectMeta object.
Returns:
A `PyInfoSubject` struct
"""
# buildifier: disable=uninitialized
public = struct(
# go/keep-sorted start
has_py2_only_sources = lambda *a, **k: _py_info_subject_has_py2_only_sources(self, *a, **k),
has_py3_only_sources = lambda *a, **k: _py_info_subject_has_py3_only_sources(self, *a, **k),
imports = lambda *a, **k: _py_info_subject_imports(self, *a, **k),
transitive_sources = lambda *a, **k: _py_info_subject_transitive_sources(self, *a, **k),
uses_shared_libraries = lambda *a, **k: _py_info_subject_uses_shared_libraries(self, *a, **k),
# go/keep-sorted end
)
self = struct(
actual = info,
meta = meta,
)
return public
def _py_info_subject_has_py2_only_sources(self):
"""Returns a `BoolSubject` for the `has_py2_only_sources` attribute.
Method: PyInfoSubject.has_py2_only_sources
"""
return subjects.bool(
self.actual.has_py2_only_sources,
meta = self.meta.derive("has_py2_only_sources()"),
)
def _py_info_subject_has_py3_only_sources(self):
"""Returns a `BoolSubject` for the `has_py3_only_sources` attribute.
Method: PyInfoSubject.has_py3_only_sources
"""
return subjects.bool(
self.actual.has_py3_only_sources,
meta = self.meta.derive("has_py3_only_sources()"),
)
def _py_info_subject_imports(self):
"""Returns a `CollectionSubject` for the `imports` attribute.
Method: PyInfoSubject.imports
"""
return subjects.collection(
self.actual.imports,
meta = self.meta.derive("imports()"),
)
def _py_info_subject_transitive_sources(self):
"""Returns a `DepsetFileSubject` for the `transitive_sources` attribute.
Method: PyInfoSubject.transitive_sources
"""
return subjects.depset_file(
self.actual.transitive_sources,
meta = self.meta.derive("transitive_sources()"),
)
def _py_info_subject_uses_shared_libraries(self):
"""Returns a `BoolSubject` for the `uses_shared_libraries` attribute.
Method: PyInfoSubject.uses_shared_libraries
"""
return subjects.bool(
self.actual.uses_shared_libraries,
meta = self.meta.derive("uses_shared_libraries()"),
)
|