From a421b0eba76cc6cda34a3347aa9062d914fd8f4f Mon Sep 17 00:00:00 2001 From: Aiden Scandella Date: Sun, 9 Feb 2020 08:06:42 -0800 Subject: [PATCH] Fix linter stdout/stderr assertions (#16) * Fix stdout linter assertions in test suite * Allow negative timezones * Fix assertions * Disable stdout assertion for prettier auto-fix --- src/linters/gofmt.js | 2 +- test/linters/linters.test.js | 16 ++++++++-------- test/linters/params/gofmt.js | 10 +++++----- test/linters/params/prettier.js | 4 +++- test/utils.js | 2 +- 5 files changed, 18 insertions(+), 16 deletions(-) diff --git a/src/linters/gofmt.js b/src/linters/gofmt.js index cff78c56..998cebe1 100644 --- a/src/linters/gofmt.js +++ b/src/linters/gofmt.js @@ -65,7 +65,7 @@ class Gofmt { // start. Without these strings, this would not be possible, because file names may include // spaces, which are not escaped in unified diffs. As a workaround, these lines are filtered out // from the gofmt diff so the diff parser can read the diff without errors - const filteredOutput = output.stderr + const filteredOutput = output.stdout .split(/\r?\n/) .filter(line => !line.startsWith("diff -u")) .join("\n"); diff --git a/test/linters/linters.test.js b/test/linters/linters.test.js index 794e7d9a..56318f69 100644 --- a/test/linters/linters.test.js +++ b/test/linters/linters.test.js @@ -65,22 +65,22 @@ describe.each([ // stdout const stdout = normalizeDates(cmdOutput.stdout); - if ("stdoutParts" in expected.lintResult) { - expected.lintResult.stdoutParts.forEach(stdoutPart => + if ("stdoutParts" in expected.cmdOutput) { + expected.cmdOutput.stdoutParts.forEach(stdoutPart => expect(stdout).toEqual(expect.stringContaining(stdoutPart)), ); - } else if ("stdout" in expected.lintResult) { - expect(stdout).toEqual(expected.stdout); + } else if ("stdout" in expected.cmdOutput) { + expect(stdout).toEqual(expected.cmdOutput.stdout); } // stderr const stderr = normalizeDates(cmdOutput.stderr); - if ("stderrParts" in expected.lintResult) { - expected.lintResult.stderrParts.forEach(stderrParts => + if ("stderrParts" in expected.cmdOutput) { + expected.cmdOutput.stderrParts.forEach(stderrParts => expect(stderr).toEqual(expect.stringContaining(stderrParts)), ); - } else if ("stderr" in expected.lintResult) { - expect(stderr).toEqual(expected.stderr); + } else if ("stderr" in expected.cmdOutput) { + expect(stderr).toEqual(expected.cmdOutput.stderr); } }); diff --git a/test/linters/params/gofmt.js b/test/linters/params/gofmt.js index 137f298b..1499fa81 100644 --- a/test/linters/params/gofmt.js +++ b/test/linters/params/gofmt.js @@ -7,14 +7,14 @@ const extensions = ["go"]; // Linting without auto-fixing function getLintParams(dir) { - const stderrFile1 = `diff -u file1.go.orig file1.go\n--- file1.go.orig ${TEST_DATE}\n+++ file1.go ${TEST_DATE}\n@@ -4,7 +4,7 @@\n \n var str = "world"\n \n-func main () { // Whitespace error\n+func main() { // Whitespace error\n fmt.Println("hello " + str)\n }\n \n@@ -17,5 +17,5 @@\n }\n \n func multiply(num1 int, num2 int) int {\n- return num1 * num2 // Indentation error\n+ return num1 * num2 // Indentation error\n }`; - const stderrFile2 = `diff -u file2.go.orig file2.go\n--- file2.go.orig ${TEST_DATE}\n+++ file2.go ${TEST_DATE}\n@@ -1,5 +1,5 @@\n package main\n \n func divide(num1 int, num2 int) int {\n- return num1 / num2 // Whitespace error\n+ return num1 / num2 // Whitespace error\n }`; + const stdoutFile1 = `diff -u file1.go.orig file1.go\n--- file1.go.orig ${TEST_DATE}\n+++ file1.go ${TEST_DATE}\n@@ -4,7 +4,7 @@\n \n var str = "world"\n \n-func main () { // Whitespace error\n+func main() { // Whitespace error\n fmt.Println("hello " + str)\n }\n \n@@ -17,5 +17,5 @@\n }\n \n func multiply(num1 int, num2 int) int {\n- return num1 * num2 // Indentation error\n+ return num1 * num2 // Indentation error\n }`; + const stdoutFile2 = `diff -u file2.go.orig file2.go\n--- file2.go.orig ${TEST_DATE}\n+++ file2.go ${TEST_DATE}\n@@ -1,5 +1,5 @@\n package main\n \n func divide(num1 int, num2 int) int {\n- return num1 / num2 // Whitespace error\n+ return num1 / num2 // Whitespace error\n }`; return { // Expected output of the linting function cmdOutput: { status: 0, // gofmt always uses exit code 0 - stderrParts: [stderrFile1, stderrFile2], - stderr: `${stderrFile1}\n${stderrFile2}`, + stdoutParts: [stdoutFile1, stdoutFile2], + stdout: `${stdoutFile1}\n${stdoutFile2}`, }, // Expected output of the parsing function lintResult: { @@ -50,7 +50,7 @@ function getFixParams(dir) { // Expected output of the linting function cmdOutput: { status: 0, // gofmt always uses exit code 0 - stderr: "", + stdout: "", }, // Expected output of the parsing function lintResult: { diff --git a/test/linters/params/prettier.js b/test/linters/params/prettier.js index 865fcf81..da214e25 100644 --- a/test/linters/params/prettier.js +++ b/test/linters/params/prettier.js @@ -55,11 +55,13 @@ function getLintParams(dir) { // Linting with auto-fixing function getFixParams(dir) { + const stdoutFile1 = `file1.js`; + const stdoutFile2 = `file2.css`; return { // Expected output of the linting function cmdOutput: { status: 0, - stdout: "", + stdoutParts: [stdoutFile1, stdoutFile2], }, // Expected output of the parsing function lintResult: { diff --git a/test/utils.js b/test/utils.js index 3d333924..d11fde9f 100644 --- a/test/utils.js +++ b/test/utils.js @@ -1,6 +1,6 @@ const { join } = require("path"); -const DATE_REGEX = /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}.\d+ \+\d{4}/g; +const DATE_REGEX = /\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}.\d+ [+-]\d{4}/g; const TEST_DATE = "2019-01-01 00:00:00.000000 +0000"; /**