mirror of
https://github.com/remoteintech/remote-jobs
synced 2025-01-12 20:48:42 +00:00
dac8b04fc8
* Prevent duplicate company names
* Fix output indentation
* Search full profile content using lunr.js
* Remove extra stop words
This wasn't really working correctly - the stop word 'work' would leave
instances of 'working' and 'works' in the index for example.
* Change company name description from "Name" to "Company name"
* Pre-process query:
- Search for terms in AND mode, per
https://lunrjs.com/guides/searching.html#term-presence
- Discard non-alphanumeric characters from the search
- Better handling of contractions and searching for stop words
* Display search query and results in the console
* Add special search token: _incomplete
* Add a link to search for incomplete profiles
* Revert "Add a link to search for incomplete profiles"
This reverts commit f6384c90cb
.
* Add link to search documentation
* Improve search explanation appearance when it spans multiple lines
* Fix searching for contractions
Previously, searching for e.g. "don't" wasn't working correctly. After
trimming the contraction, "do" is a stop word, so it should be ignored.
* Improve "empty search" message
* Prefer matches other than "company name" in search excerpts
* Move inline scripts before external scripts
This probably doesn't matter right now due to the way the scripts are
currently structured, but it might matter one day and it's more logical
this way.
* Fix search engine index progress
* Improve script indentation
* I got 99 problems and they're all bots
* Update script exit code
When a Node.js error occurs the exit code is probably going to be 1, so
we should use a different code.
* Fix the tests
* Update documentation
This was wrong (out of date), but the correct version is obvious from
reading the code.
* Make download progress work in both Chrome and Firefox
See https://stackoverflow.com/a/32799706
52 lines
1.5 KiB
JavaScript
52 lines
1.5 KiB
JavaScript
const { expect } = require( 'chai' );
|
|
|
|
const { runValidationScriptWithFixtures } = require( './lib' );
|
|
|
|
describe( 'validation script (integration tests)', () => {
|
|
it( 'should pass with valid data', () => {
|
|
expect( runValidationScriptWithFixtures( 'valid' ) ).to.eql( {
|
|
exitCode: 0,
|
|
errorSummary: '0 problems detected',
|
|
output: [],
|
|
} );
|
|
} );
|
|
|
|
it( 'should pass with valid data and incomplete profiles, and count headings', () => {
|
|
const env = { REPORT_PROFILE_HEADINGS: 'y' };
|
|
expect( runValidationScriptWithFixtures( 'valid-incomplete', env ) ).to.eql( {
|
|
exitCode: 0,
|
|
errorSummary: '0 problems detected',
|
|
output: [
|
|
'Profile headings by count (7 total profiles):',
|
|
'Company blurb: 7',
|
|
'Company size: 4',
|
|
'Remote status: 4',
|
|
'Region: 4',
|
|
'Company technologies: 3',
|
|
'How to apply: 3',
|
|
'Office locations: 1',
|
|
],
|
|
} );
|
|
} );
|
|
|
|
it( 'should catch unsorted company names, and count headings', () => {
|
|
const env = { REPORT_PROFILE_HEADINGS: 'y' };
|
|
expect( runValidationScriptWithFixtures( 'unsorted', env ) ).to.eql( {
|
|
exitCode: 3,
|
|
errorSummary: '2 problems detected',
|
|
output: [
|
|
'README.md: Company is listed out of order: "17hats" (should be before "18F")',
|
|
'README.md: Company is listed out of order: "&yet" (should be before "17hats")',
|
|
'',
|
|
'Profile headings by count (4 total profiles):',
|
|
'Company blurb: 4',
|
|
'Company size: 4',
|
|
'Remote status: 4',
|
|
'Region: 4',
|
|
'Company technologies: 4',
|
|
'Office locations: 3',
|
|
'How to apply: 4',
|
|
],
|
|
} );
|
|
} );
|
|
} );
|