diff options
| author | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-10-09 11:50:52 +0000 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-10-09 11:50:52 +0000 | 
| commit | 18c72bf15c6bc7e4c88dd06d38ff861f29d66b1b (patch) | |
| tree | f46720349e17c57db7bbfc55241b12c4410f2773 /test/shared | |
| parent | 8eddcc1785a85bbe74be254d1055ebe5125dad10 (diff) | |
| parent | 68f6211aac4177f3a70a40031dabbd1b61840071 (diff) | |
Merge pull request #655 from ueokande/partial-blacklist
Partial blacklist
Diffstat (limited to 'test/shared')
| -rw-r--r-- | test/shared/settings/Blacklist.test.ts | 183 | 
1 files changed, 132 insertions, 51 deletions
| diff --git a/test/shared/settings/Blacklist.test.ts b/test/shared/settings/Blacklist.test.ts index fbacf5d..133112c 100644 --- a/test/shared/settings/Blacklist.test.ts +++ b/test/shared/settings/Blacklist.test.ts @@ -1,77 +1,158 @@ -import Blacklist from '../../../src/shared/settings/Blacklist'; +import Blacklist, { BlacklistItem } from '../../../src/shared/settings/Blacklist';  import { expect } from 'chai'; - -describe('Blacklist', () => { -  describe('fromJSON', () => { -    it('returns empty array by empty settings', () => { -      let blacklist = Blacklist.fromJSON([]); -      expect(blacklist.toJSON()).to.be.empty; +import Key from '../../../src/shared/settings/Key'; + +describe('BlacklistItem', () => { +  describe('#fromJSON', () => { +    it('parses string pattern', () => { +      let item = BlacklistItem.fromJSON('example.com'); +      expect(item.pattern).to.equal('example.com'); +      expect(item.partial).to.be.false;      }); -    it('returns blacklist by valid settings', () => { -      let blacklist = Blacklist.fromJSON([ -        'github.com', -        'circleci.com', -      ]); - -      expect(blacklist.toJSON()).to.deep.equal([ -        'github.com', -        'circleci.com', -      ]); +    it('parses partial blacklist item', () => { +      let item = BlacklistItem.fromJSON({ url: 'example.com', keys: ['j', 'k']}); +      expect(item.pattern).to.equal('example.com'); +      expect(item.partial).to.be.true; +      expect(item.keys).to.deep.equal(['j', 'k']);      }); -    it('throws a TypeError by invalid settings', () => { -      expect(() => Blacklist.fromJSON(null)).to.throw(TypeError); -      expect(() => Blacklist.fromJSON({})).to.throw(TypeError); -      expect(() => Blacklist.fromJSON([1,2,3])).to.throw(TypeError); +    it('throws a TypeError', () => { +      expect(() => BlacklistItem.fromJSON(null)).to.throw(TypeError); +      expect(() => BlacklistItem.fromJSON(100)).to.throw(TypeError); +      expect(() => BlacklistItem.fromJSON({})).to.throw(TypeError); +      expect(() => BlacklistItem.fromJSON({url: 'google.com'})).to.throw(TypeError); +      expect(() => BlacklistItem.fromJSON({keys: ['a']})).to.throw(TypeError); +      expect(() => BlacklistItem.fromJSON({url: 'google.com', keys: 10})).to.throw(TypeError); +      expect(() => BlacklistItem.fromJSON({url: 'google.com', keys: ['a', 'b', 3]})).to.throw(TypeError);      });    }); -  describe('#includes', () => { -    it('matches by *', () => { -      let blacklist = new Blacklist(['*']); - -      expect(blacklist.includes('https://github.com/abc')).to.be.true; +  describe('#matches', () => { +    it('matches by "*"', () => { +      let item = BlacklistItem.fromJSON('*'); +      expect(item.matches(new URL('https://github.com/abc'))).to.be.true;      });      it('matches by hostname', () => { -      let blacklist = new Blacklist(['github.com']); - -      expect(blacklist.includes('https://github.com')).to.be.true; -      expect(blacklist.includes('https://gist.github.com')).to.be.false; -      expect(blacklist.includes('https://github.com/ueokande')).to.be.true; -      expect(blacklist.includes('https://github.org')).to.be.false; -      expect(blacklist.includes('https://google.com/search?q=github.org')).to.be.false; +      let item = BlacklistItem.fromJSON('github.com'); +      expect(item.matches(new URL('https://github.com'))).to.be.true; +      expect(item.matches(new URL('https://gist.github.com'))).to.be.false; +      expect(item.matches(new URL('https://github.com/ueokande'))).to.be.true; +      expect(item.matches(new URL('https://github.org'))).to.be.false; +      expect(item.matches(new URL('https://google.com/search?q=github.org'))).to.be.false;      });      it('matches by hostname with wildcard', () => { -      let blacklist = new Blacklist(['*.github.com']); +      let item = BlacklistItem.fromJSON('*.github.com'); -      expect(blacklist.includes('https://github.com')).to.be.false; -      expect(blacklist.includes('https://gist.github.com')).to.be.true; -    }) +      expect(item.matches(new URL('https://github.com'))).to.be.false; +      expect(item.matches(new URL('https://gist.github.com'))).to.be.true; +    });      it('matches by path', () => { -      let blacklist = new Blacklist(['github.com/abc']); +      let item = BlacklistItem.fromJSON('github.com/abc'); -      expect(blacklist.includes('https://github.com/abc')).to.be.true; -      expect(blacklist.includes('https://github.com/abcdef')).to.be.false; -      expect(blacklist.includes('https://gist.github.com/abc')).to.be.false; -    }) +      expect(item.matches(new URL('https://github.com/abc'))).to.be.true; +      expect(item.matches(new URL('https://github.com/abcdef'))).to.be.false; +      expect(item.matches(new URL('https://gist.github.com/abc'))).to.be.false; +    });      it('matches by path with wildcard', () => { -      let blacklist = new Blacklist(['github.com/abc*']); +      let item = BlacklistItem.fromJSON('github.com/abc*'); -      expect(blacklist.includes('https://github.com/abc')).to.be.true; -      expect(blacklist.includes('https://github.com/abcdef')).to.be.true; -      expect(blacklist.includes('https://gist.github.com/abc')).to.be.false; -    }) +      expect(item.matches(new URL('https://github.com/abc'))).to.be.true; +      expect(item.matches(new URL('https://github.com/abcdef'))).to.be.true; +      expect(item.matches(new URL('https://gist.github.com/abc'))).to.be.false; +    });      it('matches address and port', () => { -      let blacklist = new Blacklist(['127.0.0.1:8888']); +      let item = BlacklistItem.fromJSON('127.0.0.1:8888'); + +      expect(item.matches(new URL('http://127.0.0.1:8888/'))).to.be.true; +      expect(item.matches(new URL('http://127.0.0.1:8888/hello'))).to.be.true; +    }); + +    it('matches with partial blacklist', () => { +      let item = BlacklistItem.fromJSON({ url: 'google.com', keys: ['j', 'k'] }); + +      expect(item.matches(new URL('https://google.com'))).to.be.true; +      expect(item.matches(new URL('https://yahoo.com'))).to.be.false; +    }) +  }); + +  describe('#includesPartialKeys', () => { +    it('matches with partial keys', () => { +      let item = BlacklistItem.fromJSON({url: 'google.com', keys: ['j', 'k', '<C-U>']}); + +      expect(item.includeKey(new URL('http://google.com/maps'), Key.fromMapKey('j'))).to.be.true; +      expect(item.includeKey(new URL('http://google.com/maps'), Key.fromMapKey('<C-U>'))).to.be.true; +      expect(item.includeKey(new URL('http://google.com/maps'), Key.fromMapKey('z'))).to.be.false; +      expect(item.includeKey(new URL('http://google.com/maps'), Key.fromMapKey('u'))).to.be.false; +      expect(item.includeKey(new URL('http://maps.google.com/'), Key.fromMapKey('j'))).to.be.false; +    }) +  }); +}); + +describe('Blacklist', () => { +  describe('#fromJSON', () => { +    it('parses string list', () => { +      let blacklist = Blacklist.fromJSON(['example.com', 'example.org']); +      expect(blacklist.toJSON()).to.deep.equals([ +        'example.com', 'example.org', +      ]); +    }); + +    it('parses mixed blacklist', () => { +      let blacklist = Blacklist.fromJSON([ +        { url: 'example.com', keys: ['j', 'k']}, +        'example.org', +      ]); +      expect(blacklist.toJSON()).to.deep.equals([ +        { url: 'example.com', keys: ['j', 'k']}, +        'example.org', +      ]); +    }); -      expect(blacklist.includes('http://127.0.0.1:8888/')).to.be.true; -      expect(blacklist.includes('http://127.0.0.1:8888/hello')).to.be.true; +    it('parses empty blacklist', () => { +      let blacklist = Blacklist.fromJSON([]); +      expect(blacklist.toJSON()).to.deep.equals([]); +    }); + +    it('throws a TypeError', () => { +      expect(() => Blacklist.fromJSON(null)).to.throw(TypeError); +      expect(() => Blacklist.fromJSON(100)).to.throw(TypeError); +      expect(() => Blacklist.fromJSON({})).to.throw(TypeError); +      expect(() => Blacklist.fromJSON([100])).to.throw(TypeError); +      expect(() => Blacklist.fromJSON([{}])).to.throw(TypeError);      }) -  }) +  }); + +  describe('#includesEntireBlacklist', () => { +    it('matches a url with entire blacklist', () => { +      let blacklist = Blacklist.fromJSON(['google.com', '*.github.com']); +      expect(blacklist.includesEntireBlacklist(new URL('https://google.com'))).to.be.true; +      expect(blacklist.includesEntireBlacklist(new URL('https://github.com'))).to.be.false; +      expect(blacklist.includesEntireBlacklist(new URL('https://gist.github.com'))).to.be.true; +    }); + +    it('does not matches with partial blacklist', () => { +      let blacklist = Blacklist.fromJSON(['google.com', { url: 'yahoo.com', keys: ['j', 'k'] }]); +      expect(blacklist.includesEntireBlacklist(new URL('https://google.com'))).to.be.true; +      expect(blacklist.includesEntireBlacklist(new URL('https://yahoo.com'))).to.be.false; +    }); +  }); + +  describe('#includesKeys', () => { +    it('matches with entire blacklist or keys in the partial blacklist', () => { +      let blacklist = Blacklist.fromJSON([ +        'google.com', +        { url: 'github.com', keys: ['j', 'k'] }, +      ]); + +      expect(blacklist.includeKey(new URL('https://google.com'), Key.fromMapKey('j'))).to.be.true; +      expect(blacklist.includeKey(new URL('https://github.com'), Key.fromMapKey('j'))).to.be.true; +      expect(blacklist.includeKey(new URL('https://github.com'), Key.fromMapKey('a'))).to.be.false; +    }); +  });  }); | 
