From 64ab595350d25964f8d3d84bf3b0f3776dc53913 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?D=C3=A1vid=20T=C3=B3ta?= Date: Tue, 9 Jan 2024 15:10:58 +0300 Subject: [PATCH] AG-25861 Fix absolute path handling Merge in ADGUARD-FILTERS/aglint from fix/AG-25861 to master Squashed commit of the following: commit 882b9cb4eabb15f3592d38cd9d7aaee3bf12776a Author: scripthunter7 Date: Tue Jan 9 13:07:50 2024 +0100 Prepare changelog to release commit ca9c093fbde84ad475fd6a4d85529873bcd8323c Author: scripthunter7 Date: Tue Jan 9 11:20:02 2024 +0100 better test case commit 34cc587df78c4b0235034b2c992024adf2aa8c86 Author: scripthunter7 Date: Tue Jan 9 10:02:56 2024 +0100 toThrowError is deprecated commit de15dd604ddfe3ce31ecd590b00aa131ac8fae1a Author: scripthunter7 Date: Tue Jan 9 09:53:43 2024 +0100 tests commit d77efb334e907f3d094334cbe834a713990e8033 Author: scripthunter7 Date: Mon Jan 8 16:58:40 2024 +0100 Update changelog commit 33c4f4c29e279c40b5545e299318cfa9fea49e9d Author: scripthunter7 Date: Mon Jan 8 16:26:47 2024 +0100 Fix absolute path handling --- CHANGELOG.md | 8 ++++++++ src/linter/cli/index.ts | 12 +++++++++++- test/linter/cli/cli.test.ts | 24 +++++++++++++++++++++++- 3 files changed, 42 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 97cdd41..1b08fa1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,12 @@ All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog][keepachangelog], and this project adheres to [Semantic Versioning][semver]. +## [2.0.7] - 2024-01-09 + +### Fixed + +- Absolute paths in the CLI [#184]. + ## [2.0.6] - 2023-11-07 ### Added @@ -151,6 +157,7 @@ The format is based on [Keep a Changelog][keepachangelog], and this project adhe - Initial version of the adblock rule parser. +[2.0.7]: https://github.com/AdguardTeam/AGLint/compare/v2.0.6...v2.0.7 [2.0.6]: https://github.com/AdguardTeam/AGLint/compare/v2.0.5...v2.0.6 [2.0.5]: https://github.com/AdguardTeam/AGLint/compare/v2.0.4...v2.0.5 [2.0.4]: https://github.com/AdguardTeam/AGLint/compare/v2.0.3...v2.0.4 @@ -171,4 +178,5 @@ The format is based on [Keep a Changelog][keepachangelog], and this project adhe [@adguard/agtree]: https://github.com/AdguardTeam/tsurlfilter/blob/master/packages/agtree/CHANGELOG.md [#10]: https://github.com/AdguardTeam/AGLint/issues/10 +[#184]: https://github.com/AdguardTeam/AGLint/issues/184 [#185]: https://github.com/AdguardTeam/AGLint/issues/185 diff --git a/src/linter/cli/index.ts b/src/linter/cli/index.ts index ef3d5da..2e916f4 100644 --- a/src/linter/cli/index.ts +++ b/src/linter/cli/index.ts @@ -111,7 +111,17 @@ export class LinterCli { // If files are specified, use them instead of scanning the cwd if (files.length > 0) { for (const file of files) { - const fullPath = path.join(cwd, file); + let fullPath; + + if (path.isAbsolute(file)) { + // If file path is absolute, use it as is + fullPath = file; + } else { + // Otherwise, join relative path with cwd + fullPath = path.join(cwd, file); + } + + // TODO: Add support for glob patterns // Check if the file exists if (!(await pathExists(fullPath))) { diff --git a/test/linter/cli/cli.test.ts b/test/linter/cli/cli.test.ts index 89e0357..dd05ed8 100644 --- a/test/linter/cli/cli.test.ts +++ b/test/linter/cli/cli.test.ts @@ -446,8 +446,30 @@ describe('CLI tests', () => { const cli = new LinterCli(reporter); - await expect(cli.run(FIXTURE_PATH, ['dir1/dir1_file1.txt', 'dir100/dir100_file1.txt'])).rejects.toThrowError( + await expect(cli.run(FIXTURE_PATH, ['dir1/dir1_file1.txt', 'dir100/dir100_file1.txt'])).rejects.toThrow( `File "${path.join(FIXTURE_PATH, 'dir100/dir100_file1.txt')}" does not exist`, ); }); + + test('handles absolute file paths correctly', async () => { + // should work if path exists + // make 'dir1/dir1_file1.txt' absolute + const absolutePath = path.resolve(path.join(FIXTURE_PATH, 'dir1/dir1_file1.txt')); + const reporter = new TestReporter(); + const cli = new LinterCli(reporter); + await cli.run(FIXTURE_PATH, [absolutePath]); + const loggedEvents = reporter.getLoggedEvents(); + + // there are at least 4 events (onLintStart, onFileStart, onFileEnd, onLintEnd) + // no need to check the exact events here, we already did it in the previous test, + // we just want to make sure that the absolute path works + expect(loggedEvents.length).toBeGreaterThanOrEqual(4); + + // should work if path does not exist + const absolutePathNotExists = path.resolve(path.join(FIXTURE_PATH, 'dir100/dir100_file1.txt')); + + await expect(cli.run(FIXTURE_PATH, [absolutePathNotExists])).rejects.toThrow( + `File "${absolutePathNotExists}" does not exist`, + ); + }); });