Skip to content

Commit

Permalink
Add CI limit on Windows + start improving CLI
Browse files Browse the repository at this point in the history
  • Loading branch information
Jeehut committed Sep 12, 2021
1 parent 9b693e6 commit c566b0b
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 63 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,8 @@ jobs:
test-windows:
runs-on: windows-latest

timeout-minutes: 15

strategy:
matrix:
include:
Expand Down
2 changes: 2 additions & 0 deletions .github/workflows/pull-request.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,8 @@ jobs:
test-windows:
runs-on: windows-latest

timeout-minutes: 15

strategy:
matrix:
include:
Expand Down
85 changes: 32 additions & 53 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -76,63 +76,42 @@ mint install Flinesoft/AnyLint
To initialize AnyLint in a project, run:

```bash
anylint --init blank
anylint init
```

This will create the Swift script file `anylint.yml` with something like the following contents:

```yaml
CheckFileContents:
- id: Readme
hint: 'Each project should have a README.md file, explaining how to use or contribute to the project.'
regex: '^README\.md$'
violateIfNoMatchesFound: true
matchingExamples: ['README.md']
nonMatchingExamples: ['README.markdown', 'Readme.md', 'ReadMe.md']

- id: ReadmeTopLevelTitle
hint: 'The README.md file should only contain a single top level title.'
regex: '(^|\n)#[^#](.*\n)*\n#[^#]'
includeFilter: ['^README\.md$']
matchingExamples:
- |
# Title
## Subtitle
Lorem ipsum
# Other Title
## Other Subtitle
nonMatchingExamples:
- |
# Title
## Subtitle
Lorem ipsum #1 and # 2.
## Other Subtitle
### Other Subsubtitle
- id: ReadmeTypoLicense
hint: 'ReadmeTypoLicense: Misspelled word `license`.'
regex: '([\s#]L|l)isence([\s\.,:;])'
matchingExamples: [' lisence:', '## Lisence\n']
nonMatchingExamples: [' license:', '## License\n']
includeFilters: ['^README\.md$']
autoCorrectReplacement: '$1icense$2'
autoCorrectExamples:
- { before: ' lisence:', after: ' license:' }
- { before: '## Lisence\n', after: '## License\n' }

CheckFilePaths:
- id: 'ReadmePath'
hint: 'The README file should be named exactly `README.md`.'
regex: '^(.*/)?([Rr][Ee][Aa][Dd][Mm][Ee]\.markdown|readme\.md|Readme\.md|ReadMe\.md)$'
matchingExamples: ['README.markdown', 'readme.md', 'ReadMe.md']
nonMatchingExamples: ['README.md', 'CHANGELOG.md', 'CONTRIBUTING.md', 'api/help.md']
autoCorrectReplacement: '$1README.md'
autoCorrectExamples:
- { before: 'api/readme.md', after: 'api/README.md' }
- { before: 'ReadMe.md', after: 'README.md' }
- { before: 'README.markdown', after: 'README.md' }
FileContents: []
# - id: Readme
# hint: 'Each project should have a README.md file, explaining how to use or contribute to the project.'
# regex: '^README\.md$'
# violateIfNoMatchesFound: true
# matchingExamples: ['README.md']
# nonMatchingExamples: ['README.markdown', 'Readme.md', 'ReadMe.md']

FilePaths: []
# - id: 'ReadmePath'
# hint: 'The README file should be named exactly `README.md`.'
# regex: '^(.*/)?([Rr][Ee][Aa][Dd][Mm][Ee]\.markdown|readme\.md|Readme\.md|ReadMe\.md)$'
# matchingExamples: ['README.markdown', 'readme.md', 'ReadMe.md']
# nonMatchingExamples: ['README.md', 'CHANGELOG.md', 'CONTRIBUTING.md', 'api/help.md']
# autoCorrectReplacement: '$1README.md'
# autoCorrectExamples:
# - { before: 'api/readme.md', after: 'api/README.md' }
# - { before: 'ReadMe.md', after: 'README.md' }
# - { before: 'README.markdown', after: 'README.md' }

CustomScripts: []
# - id: LintConfig
# hint: 'Lint the AnyLint config file to conform to YAML best practices.'
# command: |-
# if which yamllint > /dev/null; then
# yamllint anylint.yml
# else
# echo '{ "warning": { "YamlLint: Not installed, see instructions at https://yamllint.readthedocs.io/en/stable/quickstart.html#installing-yamllint": [{}] } }'
# fi

```

Having this configuration file, you can now run `anylint` to run your lint checks. By default, if any check fails, the entire command fails and reports the violation reason. To learn more about how to configure your own checks, see the [Configuration](#configuration) section below.
Expand All @@ -141,7 +120,7 @@ If you want to create and run multiple configuration files or if you want a diff

Initializes the configuration files at the given locations:
```bash
anylint --init blank --path Sources/anylint.yml --path Tests/anylint.yml
anylint --init template=OpenSource --path Sources/anylint.yml --path Tests/anylint.yml
```

Runs the lint checks for both configuration files:
Expand Down
4 changes: 0 additions & 4 deletions Sources/Commands/InitCommand.swift
Original file line number Diff line number Diff line change
Expand Up @@ -46,11 +46,7 @@ struct InitCommand: ParsableCommand {
attributes: nil
)

log.message("Making config file executable ...", level: .info)
try shellOut(to: "chmod", arguments: ["+x", path])

log.message("Successfully created config file at \(path)", level: .success)

}
}

Expand Down
2 changes: 1 addition & 1 deletion Sources/Commands/LintCommand.swift
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ struct LintCommand: ParsableCommand {

guard FileManager.default.fileExists(atPath: config) else {
log.message(
"No configuration file found at \(config) – consider running `anylint --init` with a template.",
"No configuration file found at \(config) – consider running `anylint init` with a template.",
level: .error
)
log.exit(fail: true)
Expand Down
6 changes: 1 addition & 5 deletions Tests/ReportingTests/LintResultsTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -329,11 +329,7 @@ final class LintResultsTests: XCTestCase {
]
let encodedData = try JSONEncoder.iso.encode(lintResults)
let encodedString = String(data: encodedData, encoding: .utf8)!
XCTAssert(encodedString.contains(#""warning" : {"#))
XCTAssert(encodedString.contains(#""1@error: hint for #1" : ["#))
XCTAssert(encodedString.contains(#""discoverDate" : "2001-01-01T01:00:00Z","#))
XCTAssert(encodedString.contains(#""matchedString" : "A""#))
XCTAssert(encodedString.contains(#""filePath" : "\/some\/path""#))
XCTAssert(encodedString.count > 500)

let decodedLintResults = try JSONDecoder.iso.decode(LintResults.self, from: encodedData)
XCTAssertNoDifference(decodedLintResults, lintResults)
Expand Down

0 comments on commit c566b0b

Please sign in to comment.