mirror of
https://github.com/sphinx-doc/sphinx.git
synced 2025-02-25 18:55:22 -06:00
Merge pull request #5207 from TimKam/5186-js-test-infrastructure
5186 set up JavaScript test infrastructure
This commit is contained in:
commit
33d09e1c33
2
.gitignore
vendored
2
.gitignore
vendored
@ -29,3 +29,5 @@ doc/locale/
|
|||||||
tests/.coverage
|
tests/.coverage
|
||||||
tests/build/
|
tests/build/
|
||||||
utils/regression_test.js
|
utils/regression_test.js
|
||||||
|
|
||||||
|
node_modules/
|
||||||
|
15
.travis.yml
15
.travis.yml
@ -7,6 +7,7 @@ env:
|
|||||||
global:
|
global:
|
||||||
- PYTHONFAULTHANDLER=x
|
- PYTHONFAULTHANDLER=x
|
||||||
- SKIP_LATEX_BUILD=1
|
- SKIP_LATEX_BUILD=1
|
||||||
|
- IS_PYTHON=true
|
||||||
|
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
@ -37,11 +38,21 @@ matrix:
|
|||||||
- python: '3.6'
|
- python: '3.6'
|
||||||
env: TOXENV=flake8
|
env: TOXENV=flake8
|
||||||
|
|
||||||
|
- language: node_js
|
||||||
|
node_js:
|
||||||
|
- 10.7
|
||||||
|
env: IS_PYTHON=false
|
||||||
|
before_script:
|
||||||
|
- export DISPLAY=:99.0
|
||||||
|
- sh -e /etc/init.d/xvfb start
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- pip install -U tox codecov
|
- if [ $IS_PYTHON = true ]; then pip install -U tox codecov; fi
|
||||||
|
- if [ $IS_PYTHON = false ]; then npm install; fi
|
||||||
|
|
||||||
script:
|
script:
|
||||||
- tox -- -v
|
- if [ $IS_PYTHON = true ]; then tox -- -v; fi
|
||||||
|
- if [ $IS_PYTHON = false ]; then npm test; fi
|
||||||
|
|
||||||
after_success:
|
after_success:
|
||||||
- if [[ -e .coverage ]]; then codecov -e $TOXENV; fi
|
- if [[ -e .coverage ]]; then codecov -e $TOXENV; fi
|
||||||
|
@ -154,6 +154,12 @@ These are the basic steps needed to start developing on Sphinx.
|
|||||||
|
|
||||||
tox -e docs -- -b html,latexpdf
|
tox -e docs -- -b html,latexpdf
|
||||||
|
|
||||||
|
* To run JavaScript tests with `Karma <https://karma-runner.github.io>`_,
|
||||||
|
execute the following commands (requires `Node.js <https://nodejs.org>`_)::
|
||||||
|
|
||||||
|
npm install
|
||||||
|
npm run test
|
||||||
|
|
||||||
You can also test by installing dependencies in your local environment. ::
|
You can also test by installing dependencies in your local environment. ::
|
||||||
|
|
||||||
pip install .[test]
|
pip install .[test]
|
||||||
@ -302,8 +308,8 @@ Debugging Tips
|
|||||||
in `this repository <https://github.com/shibukawa/snowball-stemmer.jsx>`_.
|
in `this repository <https://github.com/shibukawa/snowball-stemmer.jsx>`_.
|
||||||
You can get the resulting JavaScript files using the following command::
|
You can get the resulting JavaScript files using the following command::
|
||||||
|
|
||||||
$ npm install
|
npm install
|
||||||
$ node_modules/.bin/grunt build # -> dest/*.global.js
|
node_modules/.bin/grunt build # -> dest/*.global.js
|
||||||
|
|
||||||
|
|
||||||
Branch Model
|
Branch Model
|
||||||
@ -402,3 +408,6 @@ and other ``test_*.py`` files under ``tests`` directory.
|
|||||||
|
|
||||||
.. versionadded:: 1.6
|
.. versionadded:: 1.6
|
||||||
``sphinx.testing`` as a experimental.
|
``sphinx.testing`` as a experimental.
|
||||||
|
|
||||||
|
.. versionadded:: 1.8
|
||||||
|
Sphinx also runs JavaScript tests.
|
||||||
|
72
karma.conf.js
Normal file
72
karma.conf.js
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
// Karma configuration
|
||||||
|
// Generated on Sat Jul 21 2018 22:01:48 GMT+0200 (CEST)
|
||||||
|
|
||||||
|
module.exports = function(config) {
|
||||||
|
config.set({
|
||||||
|
|
||||||
|
// base path that will be used to resolve all patterns (eg. files, exclude)
|
||||||
|
basePath: '',
|
||||||
|
|
||||||
|
|
||||||
|
// frameworks to use
|
||||||
|
// available frameworks: https://npmjs.org/browse/keyword/karma-adapter
|
||||||
|
frameworks: ['jasmine'],
|
||||||
|
|
||||||
|
|
||||||
|
// list of files / patterns to load in the browser
|
||||||
|
files: [
|
||||||
|
'sphinx/themes/basic/static/underscore.js',
|
||||||
|
'sphinx/themes/basic/static/jquery.js',
|
||||||
|
'sphinx/themes/basic/static/doctools.js',
|
||||||
|
'tests/js/*.js'
|
||||||
|
],
|
||||||
|
|
||||||
|
|
||||||
|
// list of files / patterns to exclude
|
||||||
|
exclude: [
|
||||||
|
],
|
||||||
|
|
||||||
|
|
||||||
|
// preprocess matching files before serving them to the browser
|
||||||
|
// available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
|
||||||
|
preprocessors: {
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
// test results reporter to use
|
||||||
|
// possible values: 'dots', 'progress'
|
||||||
|
// available reporters: https://npmjs.org/browse/keyword/karma-reporter
|
||||||
|
reporters: ['progress'],
|
||||||
|
|
||||||
|
|
||||||
|
// web server port
|
||||||
|
port: 9876,
|
||||||
|
|
||||||
|
|
||||||
|
// enable / disable colors in the output (reporters and logs)
|
||||||
|
colors: true,
|
||||||
|
|
||||||
|
|
||||||
|
// level of logging
|
||||||
|
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
|
||||||
|
logLevel: config.LOG_INFO,
|
||||||
|
|
||||||
|
|
||||||
|
// enable / disable watching file and executing tests whenever any file changes
|
||||||
|
autoWatch: true,
|
||||||
|
|
||||||
|
|
||||||
|
// start these browsers
|
||||||
|
// available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
|
||||||
|
browsers: ['Chrome', 'Firefox'],
|
||||||
|
|
||||||
|
|
||||||
|
// Continuous Integration mode
|
||||||
|
// if true, Karma captures browsers, runs the tests and exits
|
||||||
|
singleRun: false,
|
||||||
|
|
||||||
|
// Concurrency level
|
||||||
|
// how many browser should be started simultaneous
|
||||||
|
concurrency: Infinity
|
||||||
|
})
|
||||||
|
}
|
4456
package-lock.json
generated
Normal file
4456
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
20
package.json
Normal file
20
package.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "sphinx",
|
||||||
|
"scripts": {
|
||||||
|
"test": "./node_modules/.bin/karma start --browsers Firefox --single-run"
|
||||||
|
},
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/sphinx-doc/sphinx.git"
|
||||||
|
},
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/sphinx-doc/sphinx/issues"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"jasmine-core": "^3.1.0",
|
||||||
|
"karma": "^2.0.4",
|
||||||
|
"karma-chrome-launcher": "^2.2.0",
|
||||||
|
"karma-firefox-launcher": "^1.1.0",
|
||||||
|
"karma-jasmine": "^1.1.2"
|
||||||
|
}
|
||||||
|
}
|
@ -150,9 +150,9 @@ var Documentation = {
|
|||||||
this.fixFirefoxAnchorBug();
|
this.fixFirefoxAnchorBug();
|
||||||
this.highlightSearchWords();
|
this.highlightSearchWords();
|
||||||
this.initIndexTable();
|
this.initIndexTable();
|
||||||
{% if theme_navigation_with_keys|tobool %}
|
if (DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) {
|
||||||
this.initOnKeyListeners();
|
this.initOnKeyListeners();
|
||||||
{% endif %}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
@ -5,5 +5,20 @@ var DOCUMENTATION_OPTIONS = {
|
|||||||
COLLAPSE_INDEX: false,
|
COLLAPSE_INDEX: false,
|
||||||
FILE_SUFFIX: '{{ '' if no_search_suffix else file_suffix }}',
|
FILE_SUFFIX: '{{ '' if no_search_suffix else file_suffix }}',
|
||||||
HAS_SOURCE: {{ has_source|lower }},
|
HAS_SOURCE: {{ has_source|lower }},
|
||||||
SOURCELINK_SUFFIX: '{{ sourcelink_suffix }}'
|
SOURCELINK_SUFFIX: '{{ sourcelink_suffix }}',
|
||||||
|
NAVIGATION_WITH_KEYS: {{ 'true' if theme_navigation_with_keys|tobool else 'false'}},
|
||||||
|
SEARCH_LANGUAGE_STOP_WORDS: {{ search_language_stop_words }}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
{% if search_language_stemming_code %}
|
||||||
|
/* Non-minified version JS is _stemmer.js if file is provided */ {% endif -%}
|
||||||
|
{{ search_language_stemming_code|safe }}
|
||||||
|
|
||||||
|
{% if search_scorer_tool %}
|
||||||
|
{{ search_scorer_tool|safe }}
|
||||||
|
{% endif -%}
|
||||||
|
|
||||||
|
{% if search_word_splitter_code %}
|
||||||
|
{{ search_word_splitter_code }}
|
||||||
|
{% endif -%}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* searchtools.js_t
|
* searchtools.js
|
||||||
* ~~~~~~~~~~~~~~~~
|
* ~~~~~~~~~~~~~~~~
|
||||||
*
|
*
|
||||||
* Sphinx JavaScript utilities for the full-text search.
|
* Sphinx JavaScript utilities for the full-text search.
|
||||||
@ -9,13 +9,7 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
{% if search_language_stemming_code %}
|
if (!Scorer) {
|
||||||
/* Non-minified version JS is _stemmer.js if file is provided */ {% endif -%}
|
|
||||||
{{ search_language_stemming_code|safe }}
|
|
||||||
|
|
||||||
{% if search_scorer_tool %}
|
|
||||||
{{ search_scorer_tool|safe }}
|
|
||||||
{% else %}
|
|
||||||
/**
|
/**
|
||||||
* Simple result scoring code.
|
* Simple result scoring code.
|
||||||
*/
|
*/
|
||||||
@ -45,15 +39,13 @@ var Scorer = {
|
|||||||
// query found in terms
|
// query found in terms
|
||||||
term: 5
|
term: 5
|
||||||
};
|
};
|
||||||
{% endif %}
|
}
|
||||||
|
|
||||||
{% if search_word_splitter_code %}
|
if (!splitQuery) {
|
||||||
{{ search_word_splitter_code }}
|
|
||||||
{% else %}
|
|
||||||
function splitQuery(query) {
|
function splitQuery(query) {
|
||||||
return query.split(/\s+/);
|
return query.split(/\s+/);
|
||||||
}
|
}
|
||||||
{% endif %}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search Module
|
* Search Module
|
||||||
@ -146,7 +138,7 @@ var Search = {
|
|||||||
*/
|
*/
|
||||||
query : function(query) {
|
query : function(query) {
|
||||||
var i;
|
var i;
|
||||||
var stopwords = {{ search_language_stop_words }};
|
var stopwords = DOCUMENTATION_OPTIONS.SEARCH_LANGUAGE_STOP_WORDS;
|
||||||
|
|
||||||
// stem the searchterms and add them to the correct list
|
// stem the searchterms and add them to the correct list
|
||||||
var stemmer = new Stemmer();
|
var stemmer = new Stemmer();
|
32
tests/js/doctools.js
Normal file
32
tests/js/doctools.js
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
var DOCUMENTATION_OPTIONS = {};
|
||||||
|
|
||||||
|
describe('urldecode', function() {
|
||||||
|
|
||||||
|
it('should correctly decode URLs and replace `+`s with a spaces', function() {
|
||||||
|
var test_encoded_string =
|
||||||
|
'%D1%88%D0%B5%D0%BB%D0%BB%D1%8B+%D1%88%D0%B5%D0%BB%D0%BB%D1%8B';
|
||||||
|
var test_decoded_string = 'шеллы шеллы';
|
||||||
|
expect(jQuery.urldecode(test_encoded_string)).toEqual(test_decoded_string);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('getQueryParameters', function() {
|
||||||
|
var paramString = '?q=test+this&check_keywords=yes&area=default';
|
||||||
|
var queryParamObject = {
|
||||||
|
area: ['default'],
|
||||||
|
check_keywords: ['yes'],
|
||||||
|
q: ['test this']
|
||||||
|
};
|
||||||
|
|
||||||
|
it('should correctly create query parameter object from string', function() {
|
||||||
|
expect(jQuery.getQueryParameters(paramString)).toEqual(queryParamObject);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should correctly create query param object from URL params', function() {
|
||||||
|
history.pushState({}, '_', window.location + paramString);
|
||||||
|
expect(jQuery.getQueryParameters()).toEqual(queryParamObject);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user