This repository has been archived by the owner on Aug 7, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 23
Fixing bug where the worker thread would hang if there wasn't a tslint.json file #160
Merged
Merged
Changes from 3 commits
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
5d9fe7b
Fixing bug where the worker thread would hang if there wasn't a tslin…
Xapphire13 07b5725
Logging worker error to console. Making specs async.
Xapphire13 6601b34
Adding note about 'fit'. Adding check for 'configurationPath'
Xapphire13 bbbfe43
Merge branch 'master' of https://github.com/AtomLinter/linter-tslint …
Xapphire13 52490b3
Merging master
Xapphire13 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
const foo = 42; | ||
export default foo; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,50 +1,49 @@ | ||
'use babel'; | ||
|
||
import * as path from 'path'; | ||
// NOTE: If using 'fit' you must add it to the list below! | ||
import { beforeEach, it } from 'jasmine-fix'; // eslint-disable-line import/no-extraneous-dependencies | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Put a note here about |
||
import linterTslint from '../lib/main'; | ||
|
||
const validPath = path.join(__dirname, 'fixtures', 'valid', 'valid.ts'); | ||
const invalidPath = path.join(__dirname, 'fixtures', 'invalid', 'invalid.ts'); | ||
const noConfigPath = path.join(__dirname, 'fixtures', 'no-config', 'noConfig.ts'); | ||
const validPath = path.join(__dirname, 'fixtures', 'valid', 'valid.ts'); | ||
|
||
describe('The TSLint provider for Linter', () => { | ||
const lint = require('../lib/main.js').provideLinter().lint; | ||
|
||
beforeEach(() => { | ||
atom.workspace.destroyActivePaneItem(); | ||
|
||
waitsForPromise(() => | ||
Promise.all([ | ||
atom.packages.activatePackage('linter-tslint'), | ||
]), | ||
); | ||
}); | ||
|
||
it('finds nothing wrong with a valid file', () => { | ||
waitsForPromise(() => | ||
atom.workspace.open(validPath).then(editor => lint(editor)).then((messages) => { | ||
expect(messages.length).toBe(0); | ||
}), | ||
); | ||
}); | ||
const lint = linterTslint.provideLinter().lint; | ||
|
||
it('handles messages from TSLint', () => { | ||
const expectedMsg = 'semicolon - Missing semicolon'; | ||
waitsForPromise(() => | ||
atom.workspace.open(invalidPath).then(editor => lint(editor)).then((messages) => { | ||
expect(messages.length).toBe(1); | ||
expect(messages[0].type).toBe('warning'); | ||
expect(messages[0].html).not.toBeDefined(); | ||
expect(messages[0].text).toBe(expectedMsg); | ||
expect(messages[0].filePath).toBe(invalidPath); | ||
expect(messages[0].range).toEqual([[0, 14], [0, 14]]); | ||
}), | ||
); | ||
beforeEach(async () => { | ||
await atom.packages.activatePackage('linter-tslint'); | ||
}); | ||
|
||
it('handles undefined filepath', () => { | ||
waitsForPromise(() => | ||
atom.workspace.open().then(editor => lint(editor)).then((result) => { | ||
expect(result).toBeNull(); | ||
}), | ||
); | ||
describe('When the package is activated', () => { | ||
it('finds nothing wrong with a valid file', async () => { | ||
const editor = await atom.workspace.open(validPath); | ||
const messages = await lint(editor); | ||
expect(messages.length).toBe(0); | ||
}); | ||
|
||
it('handles messages from TSLint', async () => { | ||
const expectedMsg = 'semicolon - Missing semicolon'; | ||
const editor = await atom.workspace.open(invalidPath); | ||
const messages = await lint(editor); | ||
expect(messages.length).toBe(1); | ||
expect(messages[0].type).toBe('warning'); | ||
expect(messages[0].html).not.toBeDefined(); | ||
expect(messages[0].text).toBe(expectedMsg); | ||
expect(messages[0].filePath).toBe(invalidPath); | ||
expect(messages[0].range).toEqual([[0, 14], [0, 14]]); | ||
}); | ||
|
||
it('handles undefined filepath', async () => { | ||
const editor = await atom.workspace.open(); | ||
const result = await lint(editor); | ||
expect(result).toBeNull(); | ||
}); | ||
|
||
it('finishes validatation even when there is no tslint.json', async () => { | ||
const editor = await atom.workspace.open(noConfigPath); | ||
await lint(editor); | ||
}); | ||
}); | ||
}); |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't something be done with this crash? (Logging to the console?)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yep, will add =]