From d79cecea3eb700e16bd308d0659b3dde0af6942a Mon Sep 17 00:00:00 2001 From: Alfredo Deza Date: Tue, 28 Jul 2020 15:17:05 -0400 Subject: [PATCH] tests: verify new yarn.lock parser Signed-off-by: Alfredo Deza --- .../javascript/parse_yarn_lock_test.go | 67 +++++++++++++++++ .../javascript/test-fixtures/yarn/yarn.lock | 71 +++++++++++++++++++ 2 files changed, 138 insertions(+) create mode 100644 syft/cataloger/javascript/parse_yarn_lock_test.go create mode 100644 syft/cataloger/javascript/test-fixtures/yarn/yarn.lock diff --git a/syft/cataloger/javascript/parse_yarn_lock_test.go b/syft/cataloger/javascript/parse_yarn_lock_test.go new file mode 100644 index 000000000..3decbb86a --- /dev/null +++ b/syft/cataloger/javascript/parse_yarn_lock_test.go @@ -0,0 +1,67 @@ +package javascript + +import ( + "os" + "testing" + + "github.com/anchore/syft/syft/pkg" +) + +func TestParseYarnLock(t *testing.T) { + expected := map[string]pkg.Package{ + "@babel/code-frame": { + Name: "@babel/code-frame", + Version: "7.10.4", + Language: pkg.JavaScript, + Type: pkg.YarnPkg, + }, + "@types/minimatch": { + Name: "@types/minimatch", + Version: "3.0.3", + Language: pkg.JavaScript, + Type: pkg.YarnPkg, + }, + "@types/qs": { + Name: "@types/qs", + Version: "6.9.4", + Language: pkg.JavaScript, + Type: pkg.YarnPkg, + }, + "ajv": { + Name: "ajv", + Version: "6.12.3", + Language: pkg.JavaScript, + Type: pkg.YarnPkg, + }, + "atob": { + Name: "atob", + Version: "2.1.2", + Language: pkg.JavaScript, + Type: pkg.YarnPkg, + }, + "aws-sdk": { + Name: "aws-sdk", + Version: "2.706.0", + Language: pkg.JavaScript, + Type: pkg.YarnPkg, + }, + "jhipster-core": { + Name: "jhipster-core", + Version: "7.3.4", + Language: pkg.JavaScript, + Type: pkg.YarnPkg, + }, + } + fixture, err := os.Open("test-fixtures/yarn/yarn.lock") + if err != nil { + t.Fatalf("failed to open fixture: %+v", err) + } + + actual, err := parseYarnLock(fixture.Name(), fixture) + if err != nil { + t.Fatalf("failed to parse yarn.lock: %+v", err) + } + + assertPkgsEqual(t, actual, expected) + +} diff --git a/syft/cataloger/javascript/test-fixtures/yarn/yarn.lock b/syft/cataloger/javascript/test-fixtures/yarn/yarn.lock new file mode 100644 index 000000000..0a9ab9366 --- /dev/null +++ b/syft/cataloger/javascript/test-fixtures/yarn/yarn.lock @@ -0,0 +1,71 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.10.4": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.10.4.tgz#168da1a36e90da68ae8d49c0f1b48c7c6249213a" + integrity sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg== + dependencies: + "@babel/highlight" "^7.10.4" + +"@types/minimatch@*", "@types/minimatch@^3.0.3": + version "3.0.3" + resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.3.tgz#3dca0e3f33b200fc7d1139c0cd96c1268cadfd9d" + integrity sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA== + +"@types/qs@^6.2.31": + version "6.9.4" + resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.4.tgz#a59e851c1ba16c0513ea123830dd639a0a15cb6a" + integrity sha512-+wYo+L6ZF6BMoEjtf8zB2esQsqdV6WsjRK/GP9WOgLPrq87PbNWgIxS76dS5uvl/QXtHGakZmwTznIfcPXcKlQ== + +"@types/qs@^6.2.31": + version "6.9.4" + resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.4.tgz#a59e851c1ba16c0513ea123830dd639a0a15cb6a" + integrity sha512-+wYo+L6ZF6BMoEjtf8zB2esQsqdV6WsjRK/GP9WOgLPrq87PbNWgIxS76dS5uvl/QXtHGakZmwTznIfcPXcKlQ== + +ajv@^6.10.2, ajv@^6.5.5: + version "6.12.3" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.3.tgz#18c5af38a111ddeb4f2697bd78d68abc1cabd706" + integrity sha512-4K0cK3L1hsqk9xIb2z9vs/XU+PGJZ9PNpJRDS9YLzmNdX6jmVPfamLvTJr0aDAusnHyCHO6MjzlkAsgtqp9teA== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + +atob@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9" + integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg== + +atob@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9" + integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg== + +aws-sdk@2.706.0: + version "2.706.0" + resolved "https://registry.yarnpkg.com/aws-sdk/-/aws-sdk-2.706.0.tgz#09f65e9a91ecac5a635daf934082abae30eca953" + integrity sha512-7GT+yrB5Wb/zOReRdv/Pzkb2Qt+hz6B/8FGMVaoysX3NryHvQUdz7EQWi5yhg9CxOjKxdw5lFwYSs69YlSp1KA== + dependencies: + buffer "4.9.2" + events "1.1.1" + ieee754 "1.1.13" + jmespath "0.15.0" + querystring "0.2.0" + sax "1.2.1" + url "0.10.3" + uuid "3.3.2" + xml2js "0.4.19" + +jhipster-core@7.3.4: + version "7.3.4" + resolved "https://registry.yarnpkg.com/jhipster-core/-/jhipster-core-7.3.4.tgz#c34b8c97c7f4e8b7518dae015517e2112c73cc80" + integrity sha512-AUhT69kNkqppaJZVfan/xnKG4Gs9Ggj7YLtTZFVe+xg+THrbMb5Ng7PL07PDlDw4KAEA33GMCwuAf65E8EpC4g== + dependencies: + chevrotain "7.0.1" + fs-extra "8.1.0" + lodash "4.17.15" + winston "3.2.1" +