def test_xml_parser(self): parser = xmlparser.Parser(Builder(), StandardLogger()) test_file = utils_test.get_test_loc('formats/SPDXXmlExample.xml') with io.open(test_file, encoding='utf-8') as f: document, _ = parser.parse(f) expected_loc = utils_test.get_test_loc('doc_parse/expected.json') self.check_document(document, expected_loc)
def test_sbomyaml_parser(self): parser = yamlparser.Parser(Builder(), StandardLogger()) test_file = utils_test.get_test_loc('formats/SPDXSBOMExample.spdx.yml') with io.open(test_file, encoding='utf-8') as f: document, errors = parser.parse(f) assert not errors expected_loc = utils_test.get_test_loc('doc_parse/SBOMexpected.json') self.check_document(document, expected_loc)
def parse_JSON(file): import spdx.file as spdxfile from spdx.parsers.jsonparser import Parser from spdx.parsers.loggers import StandardLogger from spdx.parsers.jsonyamlxmlbuilders import Builder p = Parser(Builder(), StandardLogger()) with open(file) as f: doc, error = p.parse(f) if not error: print("doc comment: {0}".format(doc.comment)) print("Creators:") for c in doc.creation_info.creators: print("\t{0}".format(c)) print("Document review information:") for review in doc.reviews: print("\tReviewer: {0}".format(review.reviewer)) print("\tDate: {0}".format(review.review_date)) print("\tComment: {0}".format(review.comment)) print("Creation comment: {0}".format(doc.creation_info.comment)) print("Package Name: {0}".format(doc.package.name)) print("Package Version: {0}".format(doc.package.version)) print("Package Download Location: {0}".format( doc.package.download_location)) print("Package Homepage: {0}".format(doc.package.homepage)) print("Package Checksum: {0}".format(doc.package.check_sum.value)) print("Package verification code: {0}".format( doc.package.verif_code)) print("Package excluded from verif: {0}".format(",".join( doc.package.verif_exc_files))) print("Package license concluded: {0}".format( doc.package.conc_lics)) print("Package license declared: {0}".format( doc.package.license_declared)) print("Package licenses from files:") for lics in doc.package.licenses_from_files: print("\t{0}".format(lics)) print("Package Copyright text: {0}".format(doc.package.cr_text)) print("Package summary: {0}".format(doc.package.summary)) print("Package description: {0}".format(doc.package.description)) print("Package Files:") VALUES = { spdxfile.FileType.SOURCE: "SOURCE", spdxfile.FileType.OTHER: "OTHER", spdxfile.FileType.BINARY: "BINARY", spdxfile.FileType.ARCHIVE: "ARCHIVE", } for f in doc.files: print("\tFile name: {0}".format(f.name)) print("\tFile type: {0}".format(VALUES[f.type])) print("\tFile Checksum: {0}".format(f.chk_sum.value)) print("\tFile license concluded: {0}".format(f.conc_lics)) print("\tFile license info in file: {0}".format(",".join( map(lambda l: l.identifier, f.licenses_in_file)))) print("\tFile artifact of project name: {0}".format(",".join( f.artifact_of_project_name))) print("Document Extracted licenses:") for lics in doc.extracted_licenses: print("\tIdentifier: {0}".format(lics.identifier)) print("\tName: {0}".format(lics.full_name)) print("Annotations:") for an in doc.annotations: print("\tAnnotator: {0}".format(an.annotator)) print("\tAnnotation Date: {0}".format(an.annotation_date)) print("\tAnnotation Comment: {0}".format(an.comment)) print("\tAnnotation Type: {0}".format(an.annotation_type)) print("\tAnnotation SPDX Identifier: {0}".format(an.spdx_id)) print("Relationships: ") for rel in doc.relationships: print("\tRelationship: {0}".format(rel.relationship)) print("\tRelationship Comment: {0}".format( rel.relationship_comment)) else: print("Errors while parsing")
#!/usr/bin/env python # Parses an YAML file and prints out some basic information. # Usage: parse_yaml.py <yamlfile> if __name__ == '__main__': import sys import spdx.file as spdxfile from spdx.parsers.yamlparser import Parser from spdx.parsers.loggers import StandardLogger from spdx.parsers.jsonyamlxmlbuilders import Builder file = sys.argv[1] p = Parser(Builder(), StandardLogger()) with open(file) as f: doc, error = p.parse(f) if not error: print('doc comment: {0}'.format(doc.comment)) print('Creators:') for c in doc.creation_info.creators: print('\t{0}'.format(c)) print('Document review information:') for review in doc.reviews: print('\tReviewer: {0}'.format(review.reviewer)) print('\tDate: {0}'.format(review.review_date)) print('\tComment: {0}'.format(review.comment)) print('Creation comment: {0}'.format(doc.creation_info.comment)) print('Package Name: {0}'.format(doc.package.name)) print('Package Version: {0}'.format(doc.package.version)) print('Package Download Location: {0}'.format( doc.package.download_location)) print('Package Homepage: {0}'.format(doc.package.homepage))