diff options
| -rw-r--r-- | QA.md | 8 | ||||
| -rw-r--r-- | e2e/blacklist.test.js | 77 | ||||
| -rw-r--r-- | src/shared/blacklists.js | 4 | ||||
| -rw-r--r-- | test/shared/blacklists.test.js | 7 | 
4 files changed, 86 insertions, 10 deletions
@@ -69,14 +69,6 @@ The behaviors of the console are tested in [Console section](#consoles).  - validations in `"search"` section are not tested in this release -##### `"blacklist"` section - -- [ ] `github.com/a` blocks `github.com/a`, and not blocks `github.com/aa` -- [ ] `github.com/a*` blocks both `github.com/a` and `github.com/aa` -- [ ] `github.com/` blocks `github.com/`, and not blocks `github.com/a` -- [ ] `github.com` blocks both `github.com/` and `github.com/a` -- [ ] `*.github.com` blocks `gist.github.com/`, and not `github.com` -  ##### Updating  - [ ] changes are updated on textarea blure when no errors diff --git a/e2e/blacklist.test.js b/e2e/blacklist.test.js new file mode 100644 index 0000000..fa8e8db --- /dev/null +++ b/e2e/blacklist.test.js @@ -0,0 +1,77 @@ +const express = require('express'); +const lanthan = require('lanthan'); +const path = require('path'); +const assert = require('assert'); +const settings = require('./settings'); + +const newApp = () => { +  let app = express(); +  app.get('/*', (req, res) => { +    res.status(200).send(`<!DOCTYPEhtml> +<html lang="en"> +  <body style="width:10000px; height:10000px"></body> +</html>`); +  }); +  return app; +}; + +describe("navigate test", () => { + +  const port = 12321; +  let http; +  let firefox; +  let session; +  let browser; + +  before(async() => { +    http = newApp().listen(port); + +    firefox = await lanthan.firefox({ +      spy: path.join(__dirname, '..'), +      builderf: (builder) => { +        builder.addFile('build/settings.js'); +      }, +    }); +    session = firefox.session; +    browser = firefox.browser; +  }); + +  after(async() => { +    if (firefox) { +      await firefox.close(); +    } +    http.close(); +  }); + +  it('should disable add-on if the URL is in the blacklist', async () => { +    await browser.storage.local.set({ +      settings: { +        source: 'json', +        json: `{ +        "keymaps": { +          "j": { "type": "scroll.vertically", "count": 1 } +        }, +        "blacklist": [ "127.0.0.1:${port}/a" ] +      }`, +      }, +    }); + +    await session.navigateTo(`http://127.0.0.1:${port}/a`); + +    let body = await session.findElementByCSS('body'); +    await body.sendKeys('j'); + +    // not works +    let pageYOffset = await session.executeScript(() => window.pageYOffset); +    assert.equal(pageYOffset, 0); + +    await session.navigateTo(`http://127.0.0.1:${port}/ab`); +    body = await session.findElementByCSS('body'); +    await body.sendKeys('j'); + +    // works +    pageYOffset = await session.executeScript(() => window.pageYOffset); +    assert.equal(pageYOffset, 64); +  }); +}); + diff --git a/src/shared/blacklists.js b/src/shared/blacklists.js index 19ed3f1..61720c3 100644 --- a/src/shared/blacklists.js +++ b/src/shared/blacklists.js @@ -4,9 +4,9 @@ const includes = (blacklist, url) => {    let u = new URL(url);    return blacklist.some((item) => {      if (!item.includes('/')) { -      return re.fromWildcard(item).test(u.hostname); +      return re.fromWildcard(item).test(u.host);      } -    return re.fromWildcard(item).test(u.hostname + u.pathname); +    return re.fromWildcard(item).test(u.host + u.pathname);    });  }; diff --git a/test/shared/blacklists.test.js b/test/shared/blacklists.test.js index 87e89c5..289ea0f 100644 --- a/test/shared/blacklists.test.js +++ b/test/shared/blacklists.test.js @@ -39,4 +39,11 @@ describe("shared/blacklist", () => {      expect(includes(blacklist, 'https://github.com/abcdef')).to.be.true;      expect(includes(blacklist, 'https://gist.github.com/abc')).to.be.false;    }) + +  it('matches address and port', () => { +    let blacklist = ['127.0.0.1:8888']; + +    expect(includes(blacklist, 'http://127.0.0.1:8888/')).to.be.true; +    expect(includes(blacklist, 'http://127.0.0.1:8888/hello')).to.be.true; +  })  });  | 
