Skip to content
Open
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
318 changes: 318 additions & 0 deletions tests/types/fusesoc-test.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,318 @@
{
"$schema": "https://packageurl.org/schemas/purl-test.schema-0.1.json",
"tests": [
{
"description": "Parse test for PURL type: fusesoc",
"test_group": "base",
"test_type": "parse",
"input": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_output": {
"type": "fusesoc",
"namespace": "open-logic/open-logic",
"name": "base",
"version": "3.3.0",
"qualifiers": null,
"subpath": null
},
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_output": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There may be an extra space there?

"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "open-logic/open-logic",
"name": "base",
"version": "3.3.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Parse test for PURL type: fusesoc",
"test_group": "base",
"test_type": "parse",
"input": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_output": {
"type": "fusesoc",
"namespace": "fusesoc/utils",
"name": "blinky",
"version": "1.1.0",
"qualifiers": null,
"subpath": null
},
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_output": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc",
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Extra space in the description

"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "fusesoc/utils",
"name": "blinky",
"version": "1.1.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Parse test for PURL type: fusesoc",
"test_group": "base",
"test_type": "parse",
"input": "pkg:fusesoc/award-winning/serv/[email protected]",
"expected_output": {
"type": "fusesoc",
"namespace": "award-winning/serv",
"name": "servile",
"version": "1.3.0",
"qualifiers": null,
"subpath": null
},
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/award-winning/serv/[email protected]",
"expected_output": "pkg:fusesoc/award-winning/serv/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc",
"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "award-winning/serv",
"name": "servile",
"version": "1.3.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/award-winning/serv/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Parse test for PURL type: fusesoc",
"test_group": "base",
"test_type": "parse",
"input": "pkg:fusesoc/yosys/techlibs/[email protected]",
"expected_output": {
"type": "fusesoc",
"namespace": "yosys/techlibs",
"name": "ecp5",
"version": "0.8.0",
"qualifiers": null,
"subpath": null
},
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/yosys/techlibs/[email protected]",
"expected_output": "pkg:fusesoc/yosys/techlibs/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc",
"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "yosys/techlibs",
"name": "ecp5",
"version": "0.8.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/yosys/techlibs/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc, check case sensitivity",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_output": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc, check case sensitivity",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_output": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_failure": true,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc, check case sensitivity",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_output": "pkg:fusesoc/fusesoc/utils/[email protected]",
"expected_failure": true,
"expected_failure_reason": null
},
{
"description": "Roundtrip test for PURL type: fusesoc, check case sensitivity",
"test_group": "base",
"test_type": "roundtrip",
"input": "pkg:fusesoc/fuSesoc/utilS/[email protected]",
"expected_output": "pkg:fusesoc/fuSesoc/utilS/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Parse test for PURL type: fusesoc, check case sensitivity",
"test_group": "base",
"test_type": "parse",
"input": "pkg:fusesoc/yoSys/techLibs/[email protected]",
"expected_output": {
"type": "fusesoc",
"namespace": "yosys/techlibs",
"name": "ecp5",
"version": "0.8.0",
"qualifiers": null,
"subpath": null
},
"expected_failure": true,
"expected_failure_reason": null
},
{
"description": "Parse test for PURL type: fusesoc, check case sensitivity",
"test_group": "base",
"test_type": "parse",
"input": "pkg:fusesoc/yoSys/techLibs/[email protected]",
"expected_output": {
"type": "fusesoc",
"namespace": "yoSys/techLibs",
"name": "ecp5",
"version": "0.8.0",
"qualifiers": null,
"subpath": null
},
"expected_failure": false,
"expected_failure_reason": null
},
{
"description": "Parse test for PURL type: fusesoc, version shortening",
"test_group": "base",
"test_type": "parse",
"input": "pkg:fusesoc/yoSys/techLibs/[email protected]",
"expected_output": {
"type": "fusesoc",
"namespace": "yoSys/techLibs",
"name": "ecp5",
"version": "0.8",
"qualifiers": null,
"subpath": null
},
"expected_failure": true,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc, version shortening",
"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "open-logic/open-logic",
"name": "base",
"version": "3.3.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_failure": true,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc, case sensitivity",
"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "open-Logic/open-logic",
"name": "base",
"version": "3.3.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_failure": true,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc, case sensitivity",
"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "open-logic/open-logic",
"name": "basE",
"version": "3.3.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_failure": true,
"expected_failure_reason": null
},
{
"description": "Build test for PURL type: fusesoc, case sensitivity",
"test_group": "base",
"test_type": "build",
"input": {
"type": "fusesoc",
"namespace": "open-logic/open-logic",
"name": "basE",
"version": "3.3.0",
"qualifiers": null,
"subpath": null
},
"expected_output": "pkg:fusesoc/open-logic/open-logic/[email protected]",
"expected_failure": false,
"expected_failure_reason": null
}

]
}
33 changes: 33 additions & 0 deletions types/fusesoc-definition.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
{
"$schema": "https://packageurl.org/schemas/purl-type-definition.schema-1.0.json",
"$id": "https://packageurl.org/types/fusesoc-definition.json",
"type": "fusesoc",
"type_name": "FuseSoC core",
"description": "FuseSoC core",
"repository": {
"use_repository": true,
"default_repository_url": "https://cores.fusesoc.net"
},
"namespace_definition": {
"native_name": "vendor/library",
"case_sensitive": true,
"note": "The namespace contains both the vendor and library part of the fusesoc core name.",
"requirement": "required"
},
"name_definition": {
"requirement": "required",
"native_name": "name",
"case_sensitive": true
},
"version_definition": {
"requirement": "optional",
"native_name": "version",
"note": "The version is the semantic version of the fusesoc core. We would really like this to be required, but that breaks validation."
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not sure you need this comment.... The fact that version is optional is a spec thing when you want to refer to a package without mentioning a version like in the CVE schema, or when using that with a VERS. What about this:

Suggested change
"note": "The version is the semantic version of the fusesoc core. We would really like this to be required, but that breaks validation."
"note": "The version is the semantic version of the fusesoc core."

},
"examples": [
"pkg:fusesoc/open-logic/open-logic/[email protected]",
"pkg:fusesoc/fusesoc/utils/[email protected]",
"pkg:fusesoc/award-winning/serv/[email protected]",
"pkg:fusesoc/yosys/techlibs/[email protected]"
]
}