Skip to content

Commit 517cccc

Browse files
committed
feat: move output.BomRefDiscriminator to contrib.bom.utils.BomRefDiscriminator
Signed-off-by: Jan Kowalleck <jan.kowalleck@gmail.com>
1 parent fad302a commit 517cccc

5 files changed

Lines changed: 55 additions & 31 deletions

File tree

cyclonedx/output/json.py

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@
1919
from json import dumps as json_dumps, loads as json_loads
2020
from typing import TYPE_CHECKING, Any, Literal, Optional, Union
2121

22+
from ..contrib.bom.utils import BomRefDiscriminator
2223
from ..exception.output import FormatNotSupportedException
2324
from ..schema import OutputFormat, SchemaVersion
2425
from ..schema.schema import (
@@ -33,7 +34,7 @@
3334
SchemaVersion1Dot6,
3435
SchemaVersion1Dot7,
3536
)
36-
from . import BaseOutput, BomRefDiscriminator
37+
from . import BaseOutput
3738

3839
if TYPE_CHECKING: # pragma: no cover
3940
from ..model.bom import Bom

cyclonedx/output/xml.py

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,7 @@
2020
from xml.dom.minidom import parseString as dom_parseString # nosec B408
2121
from xml.etree.ElementTree import Element as XmlElement, tostring as xml_dumps # nosec B405
2222

23+
from ..contrib.bom.utils import BomRefDiscriminator
2324
from ..schema import OutputFormat, SchemaVersion
2425
from ..schema.schema import (
2526
SCHEMA_VERSIONS,
@@ -33,7 +34,7 @@
3334
SchemaVersion1Dot6,
3435
SchemaVersion1Dot7,
3536
)
36-
from . import BaseOutput, BomRefDiscriminator
37+
from . import BaseOutput
3738

3839
if TYPE_CHECKING: # pragma: no cover
3940
from ..model.bom import Bom

tests/__init__.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -25,7 +25,7 @@
2525

2626
from sortedcontainers import SortedSet
2727

28-
from cyclonedx.output import BomRefDiscriminator as _BomRefDiscriminator
28+
from cyclonedx.contrib.bom.utils import BomRefDiscriminator as _BomRefDiscriminator
2929
from cyclonedx.schema import OutputFormat, SchemaVersion
3030

3131
if TYPE_CHECKING:

tests/test_contrib_bom_utils.py

Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
# This file is part of CycloneDX Python Library
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+
# SPDX-License-Identifier: Apache-2.0
16+
# Copyright (c) OWASP Foundation. All Rights Reserved.
17+
18+
19+
from unittest import TestCase
20+
21+
from cyclonedx.contrib.bom.utils import BomRefDiscriminator
22+
from cyclonedx.model.bom_ref import BomRef
23+
24+
25+
class TestBomRefDiscriminator(TestCase):
26+
27+
def test_discriminate_and_reset_with(self) -> None:
28+
bomref1 = BomRef('djdlkfjdslkf')
29+
bomref2 = BomRef('djdlkfjdslkf')
30+
self.assertEqual(bomref1.value, bomref2.value, 'blank')
31+
discr = BomRefDiscriminator([bomref1, bomref2])
32+
self.assertEqual(bomref1.value, bomref2.value, 'init')
33+
discr.discriminate()
34+
self.assertNotEqual(bomref1.value, bomref2.value, 'should be discriminated')
35+
discr.reset()
36+
self.assertEqual('djdlkfjdslkf', bomref1.value)
37+
self.assertEqual('djdlkfjdslkf', bomref2.value)
38+
39+
def test_discriminate_and_reset_manually(self) -> None:
40+
bomref1 = BomRef('djdlkfjdslkf')
41+
bomref2 = BomRef('djdlkfjdslkf')
42+
self.assertEqual(bomref1.value, bomref2.value, 'blank')
43+
discr = BomRefDiscriminator([bomref1, bomref2])
44+
self.assertEqual(bomref1.value, bomref2.value, 'init')
45+
with discr:
46+
self.assertNotEqual(bomref1.value, bomref2.value, 'should be discriminated')
47+
discr.reset()
48+
self.assertEqual('djdlkfjdslkf', bomref1.value)
49+
self.assertEqual('djdlkfjdslkf', bomref2.value)

tests/test_output.py

Lines changed: 1 addition & 28 deletions
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@
2424

2525
from cyclonedx.model.bom import Bom
2626
from cyclonedx.model.bom_ref import BomRef
27-
from cyclonedx.output import BomRefDiscriminator, make_outputter
27+
from cyclonedx.output import make_outputter
2828
from cyclonedx.schema import OutputFormat, SchemaVersion
2929

3030

@@ -49,30 +49,3 @@ def test_fails_on_wrong_args(self, of: OutputFormat, sv: SchemaVersion, raises_r
4949
bom = Mock(spec=Bom)
5050
with self.assertRaisesRegex(*raises_regex):
5151
make_outputter(bom, of, sv)
52-
53-
54-
class TestBomRefDiscriminator(TestCase):
55-
56-
def test_discriminate_and_reset_with(self) -> None:
57-
bomref1 = BomRef('djdlkfjdslkf')
58-
bomref2 = BomRef('djdlkfjdslkf')
59-
self.assertEqual(bomref1.value, bomref2.value, 'blank')
60-
discr = BomRefDiscriminator([bomref1, bomref2])
61-
self.assertEqual(bomref1.value, bomref2.value, 'init')
62-
discr.discriminate()
63-
self.assertNotEqual(bomref1.value, bomref2.value, 'should be discriminated')
64-
discr.reset()
65-
self.assertEqual('djdlkfjdslkf', bomref1.value)
66-
self.assertEqual('djdlkfjdslkf', bomref2.value)
67-
68-
def test_discriminate_and_reset_manually(self) -> None:
69-
bomref1 = BomRef('djdlkfjdslkf')
70-
bomref2 = BomRef('djdlkfjdslkf')
71-
self.assertEqual(bomref1.value, bomref2.value, 'blank')
72-
discr = BomRefDiscriminator([bomref1, bomref2])
73-
self.assertEqual(bomref1.value, bomref2.value, 'init')
74-
with discr:
75-
self.assertNotEqual(bomref1.value, bomref2.value, 'should be discriminated')
76-
discr.reset()
77-
self.assertEqual('djdlkfjdslkf', bomref1.value)
78-
self.assertEqual('djdlkfjdslkf', bomref2.value)

0 commit comments

Comments
 (0)