9d38e3602b
- FileList is now an instantiable class - FileActions is now in namespace - added App class for trashbin app - moved trashbin overrides into classes extending FileList - replaced many static calls with "this." or "self." to make the classes reusable/extendable - new URL parameter "view" to specify which view is shown, for example "files" or "trashbin" - added OC.Util.History utility class in core for handling history - moved URL handling/routing to OCA.Files.App - popstate will correctly update the current view and notify the view of the URL change so it can update the current dir - added JS unitt tests for the trashbin app - fixed public app to work with the new namespaces
197 lines
5.5 KiB
JavaScript
197 lines
5.5 KiB
JavaScript
/**
|
|
* ownCloud
|
|
*
|
|
* @author Vincent Petry
|
|
* @copyright 2014 Vincent Petry <pvince81@owncloud.com>
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
* License as published by the Free Software Foundation; either
|
|
* version 3 of the License, or any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* This node module is run by the karma executable to specify its configuration.
|
|
*
|
|
* The list of files from all needed JavaScript files including the ones from the
|
|
* apps to test, and the test specs will be passed as configuration object.
|
|
*
|
|
* Note that it is possible to test a single app by setting the KARMA_TESTSUITE
|
|
* environment variable to the apps name, for example "core" or "files_encryption".
|
|
* Multiple apps can be specified by separating them with space.
|
|
*
|
|
* Setting the environment variable NOCOVERAGE to 1 will disable the coverage
|
|
* preprocessor, which is needed to be able to debug tests properly in a browser.
|
|
*/
|
|
|
|
/* jshint node: true */
|
|
module.exports = function(config) {
|
|
|
|
function findApps() {
|
|
/*
|
|
var fs = require('fs');
|
|
var apps = fs.readdirSync('apps');
|
|
return apps;
|
|
*/
|
|
// other apps tests don't run yet... needs further research / clean up
|
|
return ['files', 'files_trashbin'];
|
|
}
|
|
|
|
// respect NOCOVERAGE env variable
|
|
// it is useful to disable coverage for debugging
|
|
// because the coverage preprocessor will wrap the JS files somehow
|
|
var enableCoverage = !parseInt(process.env.NOCOVERAGE, 10);
|
|
console.log('Coverage preprocessor: ', enableCoverage?'enabled':'disabled');
|
|
|
|
// default apps to test when none is specified (TODO: read from filesystem ?)
|
|
var appsToTest = process.env.KARMA_TESTSUITE;
|
|
if (appsToTest) {
|
|
appsToTest = appsToTest.split(' ');
|
|
}
|
|
else {
|
|
appsToTest = ['core'].concat(findApps());
|
|
}
|
|
|
|
console.log('Apps to test: ', appsToTest);
|
|
|
|
// read core files from core.json,
|
|
// these are required by all apps so always need to be loaded
|
|
// note that the loading order is important that's why they
|
|
// are specified in a separate file
|
|
var corePath = 'core/js/';
|
|
var coreModule = require('../' + corePath + 'core.json');
|
|
var testCore = false;
|
|
var files = [];
|
|
var index;
|
|
var preprocessors = {};
|
|
|
|
// find out what apps to test from appsToTest
|
|
index = appsToTest.indexOf('core');
|
|
if (index > -1) {
|
|
appsToTest.splice(index, 1);
|
|
testCore = true;
|
|
}
|
|
|
|
// extra test libs
|
|
files.push(corePath + 'tests/lib/sinon-1.7.3.js');
|
|
|
|
// core mocks
|
|
files.push(corePath + 'tests/specHelper.js');
|
|
|
|
// add core library files
|
|
for ( var i = 0; i < coreModule.libraries.length; i++ ) {
|
|
var srcFile = corePath + coreModule.libraries[i];
|
|
files.push(srcFile);
|
|
}
|
|
|
|
// add core modules files
|
|
for ( var i = 0; i < coreModule.modules.length; i++ ) {
|
|
var srcFile = corePath + coreModule.modules[i];
|
|
files.push(srcFile);
|
|
if (enableCoverage) {
|
|
preprocessors[srcFile] = 'coverage';
|
|
}
|
|
}
|
|
|
|
// TODO: settings pages
|
|
|
|
// need to test the core app as well ?
|
|
if (testCore) {
|
|
// core tests
|
|
files.push(corePath + 'tests/specs/*.js');
|
|
}
|
|
|
|
for ( var i = 0; i < appsToTest.length; i++ ) {
|
|
// add app JS
|
|
var srcFile = 'apps/' + appsToTest[i] + '/js/*.js';
|
|
files.push(srcFile);
|
|
if (enableCoverage) {
|
|
preprocessors[srcFile] = 'coverage';
|
|
}
|
|
// add test specs
|
|
files.push('apps/' + appsToTest[i] + '/tests/js/*.js');
|
|
}
|
|
|
|
// serve images to avoid warnings
|
|
files.push({pattern: 'core/img/**/*', watched: false, included: false, served: true});
|
|
|
|
config.set({
|
|
|
|
// base path, that will be used to resolve files and exclude
|
|
basePath: '..',
|
|
|
|
// frameworks to use
|
|
frameworks: ['jasmine'],
|
|
|
|
// list of files / patterns to load in the browser
|
|
files: files,
|
|
|
|
// list of files to exclude
|
|
exclude: [
|
|
|
|
],
|
|
|
|
proxies: {
|
|
// prevent warnings for images
|
|
'/context.html//core/img/': 'http://localhost:9876/base/core/img/'
|
|
},
|
|
|
|
// test results reporter to use
|
|
// possible values: 'dots', 'progress', 'junit', 'growl', 'coverage'
|
|
reporters: ['dots', 'junit', 'coverage'],
|
|
|
|
junitReporter: {
|
|
outputFile: 'tests/autotest-results-js.xml'
|
|
},
|
|
|
|
// web server port
|
|
port: 9876,
|
|
|
|
preprocessors: preprocessors,
|
|
|
|
coverageReporter: {
|
|
dir:'tests/karma-coverage',
|
|
reporters: [
|
|
{ type: 'html' },
|
|
{ type: 'cobertura' }
|
|
]
|
|
},
|
|
|
|
// 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, currently available:
|
|
// - Chrome
|
|
// - ChromeCanary
|
|
// - Firefox
|
|
// - Opera (has to be installed with `npm install karma-opera-launcher`)
|
|
// - Safari (only Mac; has to be installed with `npm install karma-safari-launcher`)
|
|
// - PhantomJS
|
|
// - IE (only Windows; has to be installed with `npm install karma-ie-launcher`)
|
|
browsers: ['PhantomJS'],
|
|
|
|
// If browser does not capture in given timeout [ms], kill it
|
|
captureTimeout: 60000,
|
|
|
|
// Continuous Integration mode
|
|
// if true, it capture browsers, run tests and exit
|
|
singleRun: false
|
|
});
|
|
};
|