mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-02-01 03:12:42 +01:00
Merge branch 'develop' of github.com:ether/etherpad-lite into develop
This commit is contained in:
commit
3f11b549e9
21 changed files with 697 additions and 27 deletions
1
bin/backendTests.sh
Executable file
1
bin/backendTests.sh
Executable file
|
@ -0,0 +1 @@
|
||||||
|
src/node_modules/mocha/bin/mocha --timeout 5000 --reporter nyan tests/backend/specs/api
|
12
bin/updatePlugins.sh
Executable file
12
bin/updatePlugins.sh
Executable file
|
@ -0,0 +1,12 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
#Move to the folder where ep-lite is installed
|
||||||
|
cd `dirname $0`
|
||||||
|
|
||||||
|
#Was this script started in the bin folder? if yes move out
|
||||||
|
if [ -d "../bin" ]; then
|
||||||
|
cd "../"
|
||||||
|
fi
|
||||||
|
|
||||||
|
npm outdated --depth=0 | grep -v "^Package" | awk '{print $1}' | xargs npm install $1 --save-dev
|
||||||
|
|
|
@ -450,6 +450,7 @@ exports.handle = function(apiVersion, functionName, fields, req, res)
|
||||||
|
|
||||||
if(fields["apikey"] != apikey.trim())
|
if(fields["apikey"] != apikey.trim())
|
||||||
{
|
{
|
||||||
|
res.statusCode = 401;
|
||||||
res.send({code: 4, message: "no or wrong API Key", data: null});
|
res.send({code: 4, message: "no or wrong API Key", data: null});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,7 +40,9 @@
|
||||||
"swagger-node-express" : ">=2.1.0",
|
"swagger-node-express" : ">=2.1.0",
|
||||||
"channels" : "0.0.x",
|
"channels" : "0.0.x",
|
||||||
"jsonminify" : "0.2.2",
|
"jsonminify" : "0.2.2",
|
||||||
"measured" : "0.1.3"
|
"measured" : "0.1.3",
|
||||||
|
"mocha" : ">=2.0.1",
|
||||||
|
"supertest" : ">=0.15.0"
|
||||||
},
|
},
|
||||||
"bin": { "etherpad-lite": "./node/server.js" },
|
"bin": { "etherpad-lite": "./node/server.js" },
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
|
|
@ -1057,6 +1057,7 @@ input[type=checkbox] {
|
||||||
right:20px;
|
right:20px;
|
||||||
width:301px;
|
width:301px;
|
||||||
z-index:9999;
|
z-index:9999;
|
||||||
|
background-color:#666;
|
||||||
}
|
}
|
||||||
#gritter-notice-wrapper.bottom-right {
|
#gritter-notice-wrapper.bottom-right {
|
||||||
top: auto;
|
top: auto;
|
||||||
|
@ -1070,14 +1071,12 @@ input[type=checkbox] {
|
||||||
}
|
}
|
||||||
|
|
||||||
.gritter-top {
|
.gritter-top {
|
||||||
background:url(../../static/img/gritter.png) no-repeat left -30px;
|
|
||||||
height:10px;
|
height:10px;
|
||||||
}
|
}
|
||||||
.hover .gritter-top {
|
.hover .gritter-top {
|
||||||
background-position:right -30px;
|
background-position:right -30px;
|
||||||
}
|
}
|
||||||
.gritter-bottom {
|
.gritter-bottom {
|
||||||
background:url(../../static/img/gritter.png) no-repeat left bottom;
|
|
||||||
height:8px;
|
height:8px;
|
||||||
margin:0;
|
margin:0;
|
||||||
}
|
}
|
||||||
|
@ -1086,7 +1085,6 @@ input[type=checkbox] {
|
||||||
}
|
}
|
||||||
.gritter-item {
|
.gritter-item {
|
||||||
display:block;
|
display:block;
|
||||||
background:url(../../static/img/gritter.png) no-repeat left -40px;
|
|
||||||
color:#eee;
|
color:#eee;
|
||||||
padding:2px 11px 8px 11px;
|
padding:2px 11px 8px 11px;
|
||||||
font-size: 11px;
|
font-size: 11px;
|
||||||
|
@ -1104,7 +1102,6 @@ input[type=checkbox] {
|
||||||
position:absolute;
|
position:absolute;
|
||||||
top:5px;
|
top:5px;
|
||||||
left:3px;
|
left:3px;
|
||||||
background:url('../../static/img/gritter.png') no-repeat left top;
|
|
||||||
cursor:pointer;
|
cursor:pointer;
|
||||||
width:30px;
|
width:30px;
|
||||||
height:30px;
|
height:30px;
|
||||||
|
|
|
@ -35,7 +35,7 @@ var isNodeText = Ace2Common.isNodeText,
|
||||||
htmlPrettyEscape = Ace2Common.htmlPrettyEscape,
|
htmlPrettyEscape = Ace2Common.htmlPrettyEscape,
|
||||||
noop = Ace2Common.noop;
|
noop = Ace2Common.noop;
|
||||||
var hooks = require('./pluginfw/hooks');
|
var hooks = require('./pluginfw/hooks');
|
||||||
|
var browser = require('./browser').browser;
|
||||||
|
|
||||||
function Ace2Inner(){
|
function Ace2Inner(){
|
||||||
|
|
||||||
|
@ -51,7 +51,6 @@ function Ace2Inner(){
|
||||||
var SkipList = require('./skiplist');
|
var SkipList = require('./skiplist');
|
||||||
var undoModule = require('./undomodule').undoModule;
|
var undoModule = require('./undomodule').undoModule;
|
||||||
var AttributeManager = require('./AttributeManager');
|
var AttributeManager = require('./AttributeManager');
|
||||||
var browser = require('./browser');
|
|
||||||
|
|
||||||
var DEBUG = false; //$$ build script replaces the string "var DEBUG=true;//$$" with "var DEBUG=false;"
|
var DEBUG = false; //$$ build script replaces the string "var DEBUG=true;//$$" with "var DEBUG=false;"
|
||||||
// changed to false
|
// changed to false
|
||||||
|
|
|
@ -183,7 +183,11 @@ var padeditbar = (function()
|
||||||
var editbarHeight = $('.menu_left').height() + 2 + "px";
|
var editbarHeight = $('.menu_left').height() + 2 + "px";
|
||||||
var containerTop = $('.menu_left').height() + 7 + "px";
|
var containerTop = $('.menu_left').height() + 7 + "px";
|
||||||
$('#editbar').css("height", editbarHeight);
|
$('#editbar').css("height", editbarHeight);
|
||||||
|
|
||||||
$('#editorcontainer').css("top", containerTop);
|
$('#editorcontainer').css("top", containerTop);
|
||||||
|
if($('#options-stickychat').is(":checked")){
|
||||||
|
$('#chatbox').css("top", $('#editorcontainer').offset().top + "px");
|
||||||
|
};
|
||||||
},
|
},
|
||||||
registerDropdownCommand: function (cmd, dropdown) {
|
registerDropdownCommand: function (cmd, dropdown) {
|
||||||
dropdown = dropdown || cmd;
|
dropdown = dropdown || cmd;
|
||||||
|
|
|
@ -3,3 +3,7 @@
|
||||||
## Frontend
|
## Frontend
|
||||||
|
|
||||||
To run the tests, point your browser to `<yourdomainhere>/tests/frontend`
|
To run the tests, point your browser to `<yourdomainhere>/tests/frontend`
|
||||||
|
|
||||||
|
## Backend
|
||||||
|
|
||||||
|
To run the tests, run ``bin/backendTests.sh``
|
||||||
|
|
269
tests/backend/specs/api/pad.js
Normal file
269
tests/backend/specs/api/pad.js
Normal file
|
@ -0,0 +1,269 @@
|
||||||
|
var assert = require('assert')
|
||||||
|
supertest = require(__dirname+'/../../../../src/node_modules/supertest'),
|
||||||
|
fs = require('fs'),
|
||||||
|
api = supertest('http://localhost:9001');
|
||||||
|
path = require('path');
|
||||||
|
|
||||||
|
var filePath = path.join(__dirname, '../../../../APIKEY.txt');
|
||||||
|
|
||||||
|
var apiKey = fs.readFileSync(filePath, {encoding: 'utf-8'});
|
||||||
|
var apiVersion = 1;
|
||||||
|
var testPadId = makeid();
|
||||||
|
var lastEdited = "";
|
||||||
|
|
||||||
|
describe('Connectivity', function(){
|
||||||
|
it('errors if can not connect', function(done) {
|
||||||
|
api.get('/api/')
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('API Versioning', function(){
|
||||||
|
it('errors if can not connect', function(done) {
|
||||||
|
api.get('/api/')
|
||||||
|
.expect(function(res){
|
||||||
|
apiVersion = res.body.currentVersion;
|
||||||
|
if (!res.body.currentVersion) throw new Error("No version set in API");
|
||||||
|
return;
|
||||||
|
})
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('Permission', function(){
|
||||||
|
it('errors if can connect without correct APIKey', function(done) {
|
||||||
|
// This is broken because Etherpad doesn't handle HTTP codes properly see #2343
|
||||||
|
// If your APIKey is password you deserve to fail all tests anyway
|
||||||
|
var permErrorURL = '/api/'+apiVersion+'/createPad?apikey=password&padID=test';
|
||||||
|
api.get(permErrorURL)
|
||||||
|
.expect(401, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
/* Pad Tests Order of execution
|
||||||
|
-> deletePad -- This gives us a guaranteed clear environment
|
||||||
|
-> createPad
|
||||||
|
-> getRevisions -- Should be 0
|
||||||
|
-> getHTML -- Should be the default pad text in HTML format
|
||||||
|
-> deletePad -- Should just delete a pad
|
||||||
|
-> getHTML -- Should return an error
|
||||||
|
-> createPad(withText)
|
||||||
|
-> getText -- Should have the text specified above as the pad text
|
||||||
|
-> setText
|
||||||
|
-> getText -- Should be the text set before
|
||||||
|
-> getRevisions -- Should be 0 still?
|
||||||
|
-> padUsersCount -- Should be 0
|
||||||
|
-> getReadOnlyId -- Should be a value
|
||||||
|
-> listAuthorsOfPad(padID) -- should be empty array?
|
||||||
|
-> getLastEdited(padID) -- Should be when pad was made
|
||||||
|
-> setText(padId)
|
||||||
|
-> getLastEdited(padID) -- Should be when setText was performed
|
||||||
|
*/
|
||||||
|
|
||||||
|
describe('deletePad', function(){
|
||||||
|
it('deletes a Pad', function(done) {
|
||||||
|
api.get(endPoint('deletePad')+"&padID="+testPadId)
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createPad', function(){
|
||||||
|
it('creates a new Pad', function(done) {
|
||||||
|
api.get(endPoint('createPad')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to create new Pad");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getRevisionsCount', function(){
|
||||||
|
it('gets revision count of Pad', function(done) {
|
||||||
|
api.get(endPoint('getRevisionsCount')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to get Revision Count");
|
||||||
|
if(res.body.data.revisions !== 0) throw new Error("Incorrect Revision Count");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getHTML', function(){
|
||||||
|
it('get the HTML of Pad', function(done) {
|
||||||
|
api.get(endPoint('getHTML')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.data.html.length <= 1) throw new Error("Unable to get Revision Count");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('deletePad', function(){
|
||||||
|
it('deletes a Pad', function(done) {
|
||||||
|
api.get(endPoint('deletePad')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Pad Deletion failed")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getHTML', function(){
|
||||||
|
it('get the HTML of a Pad -- Should return a failure', function(done) {
|
||||||
|
api.get(endPoint('getHTML')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 1) throw new Error("Pad deletion failed")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createPad', function(){
|
||||||
|
it('creates a new Pad with text', function(done) {
|
||||||
|
api.get(endPoint('createPad')+"&padID="+testPadId+"&text=testText")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Pad Creation failed")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getText', function(){
|
||||||
|
it('gets the Pad text and expect it to be testText with \n which is a line break', function(done) {
|
||||||
|
api.get(endPoint('getText')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.data.text !== "testText\n") throw new Error("Pad Creation with text")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('setText', function(){
|
||||||
|
it('creates a new Pad with text', function(done) {
|
||||||
|
api.get(endPoint('setText')+"&padID="+testPadId+"&text=testTextTwo")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Pad setting text failed");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getText', function(){
|
||||||
|
it('gets the Pad text', function(done) {
|
||||||
|
api.get(endPoint('getText')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.data.text !== "testTextTwo\n") throw new Error("Setting Text")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getRevisionsCount', function(){
|
||||||
|
it('gets Revision Coutn of a Pad', function(done) {
|
||||||
|
api.get(endPoint('getRevisionsCount')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.data.revisions !== 1) throw new Error("Unable to set text revision count")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('padUsersCount', function(){
|
||||||
|
it('gets User Count of a Pad', function(done) {
|
||||||
|
api.get(endPoint('padUsersCount')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.data.padUsersCount !== 0) throw new Error("Incorrect Pad User count")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getReadOnlyID', function(){
|
||||||
|
it('Gets the Read Only ID of a Pad', function(done) {
|
||||||
|
api.get(endPoint('getReadOnlyID')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(!res.body.data.readOnlyID) throw new Error("No Read Only ID for Pad")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('listAuthorsOfPad', function(){
|
||||||
|
it('Get Authors of the Pad', function(done) {
|
||||||
|
api.get(endPoint('listAuthorsOfPad')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.data.authorIDs.length !== 0) throw new Error("# of Authors of pad is not 0")
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getLastEdited', function(){
|
||||||
|
it('Get When Pad was left Edited', function(done) {
|
||||||
|
api.get(endPoint('getLastEdited')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(!res.body.data.lastEdited){
|
||||||
|
throw new Error("# of Authors of pad is not 0")
|
||||||
|
}else{
|
||||||
|
lastEdited = res.body.data.lastEdited;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('setText', function(){
|
||||||
|
it('creates a new Pad with text', function(done) {
|
||||||
|
api.get(endPoint('setText')+"&padID="+testPadId+"&text=testTextTwo")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Pad setting text failed");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getLastEdited', function(){
|
||||||
|
it('Get When Pad was left Edited', function(done) {
|
||||||
|
api.get(endPoint('getLastEdited')+"&padID="+testPadId)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.data.lastEdited <= lastEdited){
|
||||||
|
throw new Error("Editing A Pad is not updating when it was last edited")
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
var endPoint = function(point){
|
||||||
|
return '/api/'+apiVersion+'/'+point+'?apikey='+apiKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
function makeid()
|
||||||
|
{
|
||||||
|
var text = "";
|
||||||
|
var possible = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
|
||||||
|
|
||||||
|
for( var i=0; i < 5; i++ ){
|
||||||
|
text += possible.charAt(Math.floor(Math.random() * possible.length));
|
||||||
|
}
|
||||||
|
return text;
|
||||||
|
}
|
363
tests/backend/specs/api/sessionsAndGroups.js
Normal file
363
tests/backend/specs/api/sessionsAndGroups.js
Normal file
|
@ -0,0 +1,363 @@
|
||||||
|
var assert = require('assert')
|
||||||
|
supertest = require(__dirname+'/../../../../src/node_modules/supertest'),
|
||||||
|
fs = require('fs'),
|
||||||
|
api = supertest('http://localhost:9001');
|
||||||
|
path = require('path');
|
||||||
|
|
||||||
|
var filePath = path.join(__dirname, '../../../../APIKEY.txt');
|
||||||
|
|
||||||
|
var apiKey = fs.readFileSync(filePath, {encoding: 'utf-8'});
|
||||||
|
var apiVersion = 1;
|
||||||
|
var testPadId = makeid();
|
||||||
|
var groupID = "";
|
||||||
|
var authorID = "";
|
||||||
|
var sessionID = "";
|
||||||
|
var padID = makeid();
|
||||||
|
|
||||||
|
describe('API Versioning', function(){
|
||||||
|
it('errors if can not connect', function(done) {
|
||||||
|
api.get('/api/')
|
||||||
|
.expect(function(res){
|
||||||
|
apiVersion = res.body.currentVersion;
|
||||||
|
if (!res.body.currentVersion) throw new Error("No version set in API");
|
||||||
|
return;
|
||||||
|
})
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
// BEGIN GROUP AND AUTHOR TESTS
|
||||||
|
/////////////////////////////////////
|
||||||
|
/////////////////////////////////////
|
||||||
|
|
||||||
|
/* Tests performed
|
||||||
|
-> createGroup() -- should return a groupID
|
||||||
|
-> listSessionsOfGroup(groupID) -- should be 0
|
||||||
|
-> deleteGroup(groupID)
|
||||||
|
-> createGroupIfNotExistsFor(groupMapper) -- should return a groupID
|
||||||
|
|
||||||
|
-> createAuthor([name]) -- should return an authorID
|
||||||
|
-> createAuthorIfNotExistsFor(authorMapper [, name]) -- should return an authorID
|
||||||
|
-> getAuthorName(authorID) -- should return a name IE "john"
|
||||||
|
|
||||||
|
-> createSession(groupID, authorID, validUntil)
|
||||||
|
-> getSessionInfo(sessionID)
|
||||||
|
-> listSessionsOfGroup(groupID) -- should be 1
|
||||||
|
-> deleteSession(sessionID)
|
||||||
|
-> getSessionInfo(sessionID) -- should have author id etc in
|
||||||
|
|
||||||
|
-> listPads(groupID) -- should be empty array
|
||||||
|
-> createGroupPad(groupID, padName [, text])
|
||||||
|
-> listPads(groupID) -- should be empty array
|
||||||
|
-> getPublicStatus(padId)
|
||||||
|
-> setPublicStatus(padId, status)
|
||||||
|
-> getPublicStatus(padId)
|
||||||
|
-> isPasswordProtected(padID) -- should be false
|
||||||
|
-> setPassword(padID, password)
|
||||||
|
-> isPasswordProtected(padID) -- should be true
|
||||||
|
|
||||||
|
-> listPadsOfAuthor(authorID)
|
||||||
|
*/
|
||||||
|
|
||||||
|
describe('createGroup', function(){
|
||||||
|
it('creates a new group', function(done) {
|
||||||
|
api.get(endPoint('createGroup'))
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.groupID) throw new Error("Unable to create new Pad");
|
||||||
|
groupID = res.body.data.groupID;
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('listSessionsOfGroup', function(){
|
||||||
|
it('Lists the session of a group', function(done) {
|
||||||
|
api.get(endPoint('listSessionsOfGroup')+"&groupID="+groupID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || res.body.data !== null) throw new Error("Sessions show as existing for this group");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('deleteGroup', function(){
|
||||||
|
it('Deletes a group', function(done) {
|
||||||
|
api.get(endPoint('deleteGroup')+"&groupID="+groupID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Group failed to be deleted");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createGroupIfNotExistsFor', function(){
|
||||||
|
it('Creates a group if one doesnt exist for mapper 0', function(done) {
|
||||||
|
api.get(endPoint('createGroupIfNotExistsFor')+"&groupMapper=management")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.groupID) throw new Error("Sessions show as existing for this group");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createGroup', function(){
|
||||||
|
it('creates a new group', function(done) {
|
||||||
|
api.get(endPoint('createGroup'))
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.groupID) throw new Error("Unable to create new Pad");
|
||||||
|
groupID = res.body.data.groupID;
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createAuthor', function(){
|
||||||
|
it('Creates an author with a name set', function(done) {
|
||||||
|
api.get(endPoint('createAuthor'))
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.authorID) throw new Error("Unable to create author");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createAuthor', function(){
|
||||||
|
it('Creates an author with a name set', function(done) {
|
||||||
|
api.get(endPoint('createAuthor')+"&name=john")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.authorID) throw new Error("Unable to create user with name set");
|
||||||
|
authorID = res.body.data.authorID; // we will be this author for the rest of the tests
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createAuthorIfNotExistsFor', function(){
|
||||||
|
it('Creates an author if it doesnt exist already and provides mapping', function(done) {
|
||||||
|
api.get(endPoint('createAuthorIfNotExistsFor')+"&authorMapper=chris")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.authorID) throw new Error("Unable to create author with mapper");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getAuthorName', function(){
|
||||||
|
it('Gets the author name', function(done) {
|
||||||
|
api.get(endPoint('getAuthorName')+"&authorID="+authorID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data === "john") throw new Error("Unable to get Author Name from Author ID");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
// BEGIN SESSION TESTS
|
||||||
|
///////////////////////////////////////
|
||||||
|
///////////////////////////////////////
|
||||||
|
|
||||||
|
describe('createSession', function(){
|
||||||
|
it('Creates a session for an Author', function(done) {
|
||||||
|
api.get(endPoint('createSession')+"&authorID="+authorID+"&groupID="+groupID+"&validUntil=999999999999")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.sessionID) throw new Error("Unable to create Session");
|
||||||
|
sessionID = res.body.data.sessionID;
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getSessionInfo', function(){
|
||||||
|
it('Gets session inf', function(done) {
|
||||||
|
api.get(endPoint('getSessionInfo')+"&sessionID="+sessionID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.groupID || !res.body.data.authorID || !res.body.data.validUntil) throw new Error("Unable to get Session info");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('listSessionsOfGroup', function(){
|
||||||
|
it('Gets sessions of a group', function(done) {
|
||||||
|
api.get(endPoint('listSessionsOfGroup')+"&groupID="+groupID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || typeof res.body.data !== "object") throw new Error("Unable to get sessions of a group");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('deleteSession', function(){
|
||||||
|
it('Deletes a session', function(done) {
|
||||||
|
api.get(endPoint('deleteSession')+"&sessionID="+sessionID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to delete a session");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getSessionInfo', function(){
|
||||||
|
it('Gets session info', function(done) {
|
||||||
|
api.get(endPoint('getSessionInfo')+"&sessionID="+sessionID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 1) throw new Error("Session was not properly deleted");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
// GROUP PAD MANAGEMENT
|
||||||
|
///////////////////////////////////////
|
||||||
|
///////////////////////////////////////
|
||||||
|
|
||||||
|
describe('listPads', function(){
|
||||||
|
it('Lists Pads of a Group', function(done) {
|
||||||
|
api.get(endPoint('listPads')+"&groupID="+groupID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || res.body.data.padIDs.length !== 0) throw new Error("Group already had pads for some reason"+res.body.data.padIDs);
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('createGroupPad', function(){
|
||||||
|
it('Creates a Group Pad', function(done) {
|
||||||
|
api.get(endPoint('createGroupPad')+"&groupID="+groupID+"&padName="+padID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unable to create group pad");
|
||||||
|
padID = res.body.data.padID;
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('listPads', function(){
|
||||||
|
it('Lists Pads of a Group', function(done) {
|
||||||
|
api.get(endPoint('listPads')+"&groupID="+groupID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || res.body.data.padIDs.length !== 1) throw new Error("Group isnt listing this pad");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
// PAD SECURITY /-_-\
|
||||||
|
///////////////////////////////////////
|
||||||
|
///////////////////////////////////////
|
||||||
|
|
||||||
|
describe('getPublicStatus', function(){
|
||||||
|
it('Gets the public status of a pad', function(done) {
|
||||||
|
api.get(endPoint('getPublicStatus')+"&padID="+padID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || res.body.data.publicstatus) throw new Error("Unable to get public status of this pad");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('setPublicStatus', function(){
|
||||||
|
it('Sets the public status of a pad', function(done) {
|
||||||
|
api.get(endPoint('setPublicStatus')+"&padID="+padID+"&publicStatus=true")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Setting status did not work");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('getPublicStatus', function(){
|
||||||
|
it('Gets the public status of a pad', function(done) {
|
||||||
|
api.get(endPoint('getPublicStatus')+"&padID="+padID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.publicStatus) throw new Error("Setting public status of this pad did not work");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isPasswordProtected', function(){
|
||||||
|
it('Gets the public status of a pad', function(done) {
|
||||||
|
api.get(endPoint('isPasswordProtected')+"&padID="+padID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || res.body.data.isPasswordProtected) throw new Error("Pad is password protected by default");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('setPassword', function(){
|
||||||
|
it('Gets the public status of a pad', function(done) {
|
||||||
|
api.get(endPoint('setPassword')+"&padID="+padID+"&password=test")
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0) throw new Error("Unabe to set password");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('isPasswordProtected', function(){
|
||||||
|
it('Gets the public status of a pad', function(done) {
|
||||||
|
api.get(endPoint('isPasswordProtected')+"&padID="+padID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || !res.body.data.isPasswordProtected) throw new Error("Pad password protection has not applied");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
// NOT SURE HOW TO POPULAT THIS /-_-\
|
||||||
|
///////////////////////////////////////
|
||||||
|
///////////////////////////////////////
|
||||||
|
|
||||||
|
describe('listPadsOfAuthor', function(){
|
||||||
|
it('Gets the Pads of an Author', function(done) {
|
||||||
|
api.get(endPoint('listPadsOfAuthor')+"&authorID="+authorID)
|
||||||
|
.expect(function(res){
|
||||||
|
if(res.body.code !== 0 || res.body.data.padIDs.length !== 0) throw new Error("Pad password protection has not applied");
|
||||||
|
})
|
||||||
|
.expect('Content-Type', /json/)
|
||||||
|
.expect(200, done)
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var endPoint = function(point){
|
||||||
|
return '/api/'+apiVersion+'/'+point+'?apikey='+apiKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
function makeid()
|
||||||
|
{
|
||||||
|
var text = "";
|
||||||
|
var possible = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
|
||||||
|
|
||||||
|
for( var i=0; i < 5; i++ ){
|
||||||
|
text += possible.charAt(Math.floor(Math.random() * possible.length));
|
||||||
|
}
|
||||||
|
return text;
|
||||||
|
}
|
|
@ -10,7 +10,7 @@
|
||||||
<div id="iframe-container"></div>
|
<div id="iframe-container"></div>
|
||||||
|
|
||||||
<script src="/static/js/jquery.js"></script>
|
<script src="/static/js/jquery.js"></script>
|
||||||
<script src="/static/js/jquery_browser.js"></script>
|
<script src="/static/js/browser.js"></script>
|
||||||
<script src="lib/underscore.js"></script>
|
<script src="lib/underscore.js"></script>
|
||||||
|
|
||||||
<script src="lib/mocha.js"></script>
|
<script src="lib/mocha.js"></script>
|
||||||
|
@ -22,6 +22,5 @@
|
||||||
<script src="helper.js"></script>
|
<script src="helper.js"></script>
|
||||||
|
|
||||||
<script src="specs_list.js"></script>
|
<script src="specs_list.js"></script>
|
||||||
|
|
||||||
<script src="runner.js"></script>
|
<script src="runner.js"></script>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -2,8 +2,9 @@
|
||||||
(function($) {
|
(function($) {
|
||||||
$.fn.purgeFrame = function() {
|
$.fn.purgeFrame = function() {
|
||||||
var deferred;
|
var deferred;
|
||||||
|
var browser = bowser;
|
||||||
|
|
||||||
if ($.browser.msie && parseFloat($.browser.version, 10) < 9) {
|
if (browser.msie && parseFloat(browser.version, 10) < 9) {
|
||||||
deferred = purge(this);
|
deferred = purge(this);
|
||||||
} else {
|
} else {
|
||||||
this.remove();
|
this.remove();
|
||||||
|
@ -36,4 +37,4 @@
|
||||||
|
|
||||||
return deferred.promise();
|
return deferred.promise();
|
||||||
}
|
}
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
|
|
@ -162,7 +162,8 @@ $(function(){
|
||||||
}
|
}
|
||||||
|
|
||||||
//allow cross iframe access
|
//allow cross iframe access
|
||||||
if ((!$.browser.msie) && (!($.browser.mozilla && $.browser.version.indexOf("1.8.") == 0))) {
|
var browser = bowser;
|
||||||
|
if ((!browser.msie) && (!(browser.mozilla && browser.version.indexOf("1.8.") == 0))) {
|
||||||
document.domain = document.domain; // for comet
|
document.domain = document.domain; // for comet
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,9 @@ describe("bold button", function(){
|
||||||
|
|
||||||
//select this text element
|
//select this text element
|
||||||
$firstTextElement.sendkeys('{selectall}');
|
$firstTextElement.sendkeys('{selectall}');
|
||||||
if(inner$.browser.mozilla){ // if it's a mozilla browser
|
console.log(inner$(window)[0].bowser);
|
||||||
|
|
||||||
|
if(inner$(window)[0].bowser.firefox){ // if it's a mozilla browser
|
||||||
var evtType = "keypress";
|
var evtType = "keypress";
|
||||||
}else{
|
}else{
|
||||||
var evtType = "keydown";
|
var evtType = "keydown";
|
||||||
|
|
|
@ -1,11 +1,19 @@
|
||||||
describe("As the caret is moved is the UI properly updated?", function(){
|
describe("As the caret is moved is the UI properly updated?", function(){
|
||||||
var padName;
|
var padName;
|
||||||
var numberOfRows = 50;
|
var numberOfRows = 50;
|
||||||
|
/*
|
||||||
|
|
||||||
it("creates a pad", function(done) {
|
//create a new pad before each test run
|
||||||
|
beforeEach(function(cb){
|
||||||
|
helper.newPad(cb);
|
||||||
|
this.timeout(60000);
|
||||||
|
});
|
||||||
|
|
||||||
|
xit("creates a pad", function(done) {
|
||||||
padName = helper.newPad(done);
|
padName = helper.newPad(done);
|
||||||
this.timeout(60000);
|
this.timeout(60000);
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
|
|
||||||
/* Tests to do
|
/* Tests to do
|
||||||
* Keystroke up (38), down (40), left (37), right (39) with and without special keys IE control / shift
|
* Keystroke up (38), down (40), left (37), right (39) with and without special keys IE control / shift
|
||||||
|
@ -20,10 +28,12 @@ describe("As the caret is moved is the UI properly updated?", function(){
|
||||||
* How do we keep the authors focus on a line if the lines above the author are modified? We should only redraw the user to a location if they are typing and make sure shift and arrow keys aren't redrawing the UI else highlight - copy/paste would get broken
|
* How do we keep the authors focus on a line if the lines above the author are modified? We should only redraw the user to a location if they are typing and make sure shift and arrow keys aren't redrawing the UI else highlight - copy/paste would get broken
|
||||||
* How can we simulate an edit event in the test framework?
|
* How can we simulate an edit event in the test framework?
|
||||||
*/
|
*/
|
||||||
|
/*
|
||||||
// THIS DOESNT WORK AS IT DOESNT MOVE THE CURSOR!
|
// THIS DOESNT WORK IN CHROME AS IT DOESNT MOVE THE CURSOR!
|
||||||
it("down arrow", function(done){
|
it("down arrow", function(done){
|
||||||
var inner$ = helper.padInner$;
|
var inner$ = helper.padInner$;
|
||||||
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
||||||
var $newFirstTextElement = inner$("div").first();
|
var $newFirstTextElement = inner$("div").first();
|
||||||
$newFirstTextElement.focus();
|
$newFirstTextElement.focus();
|
||||||
keyEvent(inner$, 37, false, false); // arrow down
|
keyEvent(inner$, 37, false, false); // arrow down
|
||||||
|
@ -31,9 +41,10 @@ describe("As the caret is moved is the UI properly updated?", function(){
|
||||||
|
|
||||||
done();
|
done();
|
||||||
});
|
});
|
||||||
/*
|
|
||||||
it("Creates N lines", function(done){
|
it("Creates N lines", function(done){
|
||||||
var inner$ = helper.padInner$;
|
var inner$ = helper.padInner$;
|
||||||
|
console.log(inner$);
|
||||||
var chrome$ = helper.padChrome$;
|
var chrome$ = helper.padChrome$;
|
||||||
var $newFirstTextElement = inner$("div").first();
|
var $newFirstTextElement = inner$("div").first();
|
||||||
|
|
||||||
|
@ -224,7 +235,6 @@ describe("As the caret is moved is the UI properly updated?", function(){
|
||||||
});
|
});
|
||||||
var i = 0;
|
var i = 0;
|
||||||
while(i < numberOfRows){ // press down arrow
|
while(i < numberOfRows){ // press down arrow
|
||||||
console.log("dwn");
|
|
||||||
keyEvent(inner$, 40, false, false);
|
keyEvent(inner$, 40, false, false);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
@ -287,7 +297,7 @@ function prepareDocument(n, target){ // generates a random document with random
|
||||||
}
|
}
|
||||||
|
|
||||||
function keyEvent(target, charCode, ctrl, shift){ // sends a charCode to the window
|
function keyEvent(target, charCode, ctrl, shift){ // sends a charCode to the window
|
||||||
if(target.browser.mozilla){ // if it's a mozilla browser
|
if(inner$(window)[0].bowser.firefox){ // if it's a mozilla browser
|
||||||
var evtType = "keypress";
|
var evtType = "keypress";
|
||||||
}else{
|
}else{
|
||||||
var evtType = "keydown";
|
var evtType = "keydown";
|
||||||
|
|
|
@ -15,7 +15,7 @@ describe("indentation button", function(){
|
||||||
//select this text element
|
//select this text element
|
||||||
$firstTextElement.sendkeys('{selectall}');
|
$firstTextElement.sendkeys('{selectall}');
|
||||||
|
|
||||||
if(inner$.browser.mozilla){ // if it's a mozilla browser
|
if(inner$(window)[0].bowser.firefox){ // if it's a mozilla browser
|
||||||
var evtType = "keypress";
|
var evtType = "keypress";
|
||||||
}else{
|
}else{
|
||||||
var evtType = "keydown";
|
var evtType = "keydown";
|
||||||
|
|
|
@ -44,7 +44,7 @@ describe("italic some text", function(){
|
||||||
//select this text element
|
//select this text element
|
||||||
$firstTextElement.sendkeys('{selectall}');
|
$firstTextElement.sendkeys('{selectall}');
|
||||||
|
|
||||||
if(inner$.browser.mozilla){ // if it's a mozilla browser
|
if(inner$(window)[0].bowser.firefox){ // if it's a mozilla browser
|
||||||
var evtType = "keypress";
|
var evtType = "keypress";
|
||||||
}else{
|
}else{
|
||||||
var evtType = "keydown";
|
var evtType = "keydown";
|
||||||
|
|
|
@ -47,7 +47,7 @@ describe("undo button then redo button", function(){
|
||||||
var modifiedValue = $firstTextElement.text(); // get the modified value
|
var modifiedValue = $firstTextElement.text(); // get the modified value
|
||||||
expect(modifiedValue).not.to.be(originalValue); // expect the value to change
|
expect(modifiedValue).not.to.be(originalValue); // expect the value to change
|
||||||
|
|
||||||
if(inner$.browser.mozilla){ // if it's a mozilla browser
|
if(inner$(window)[0].bowser.firefox){ // if it's a mozilla browser
|
||||||
var evtType = "keypress";
|
var evtType = "keypress";
|
||||||
}else{
|
}else{
|
||||||
var evtType = "keydown";
|
var evtType = "keydown";
|
||||||
|
|
|
@ -19,7 +19,7 @@ describe('Responsiveness of Editor', function() {
|
||||||
helper.newPad(cb);
|
helper.newPad(cb);
|
||||||
this.timeout(6000);
|
this.timeout(6000);
|
||||||
});
|
});
|
||||||
it('Fast response to keypress in pad with large amount of contents', function(done) {
|
xit('Fast response to keypress in pad with large amount of contents', function(done) {
|
||||||
var inner$ = helper.padInner$;
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.padChrome$;
|
var chrome$ = helper.padChrome$;
|
||||||
var chars = '0000000000'; // row of placeholder chars
|
var chars = '0000000000'; // row of placeholder chars
|
||||||
|
|
|
@ -4,7 +4,8 @@ describe("timeslider", function(){
|
||||||
helper.newPad(cb);
|
helper.newPad(cb);
|
||||||
this.timeout(6000);
|
this.timeout(6000);
|
||||||
});
|
});
|
||||||
it("loads adds a hundred revisions", function(done) {
|
|
||||||
|
it("loads adds a hundred revisions", function(done) { // passes
|
||||||
var inner$ = helper.padInner$;
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.padChrome$;
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
||||||
|
@ -56,7 +57,10 @@ describe("timeslider", function(){
|
||||||
}, 6000);
|
}, 6000);
|
||||||
}, revs*timePerRev);
|
}, revs*timePerRev);
|
||||||
});
|
});
|
||||||
it("changes the url when clicking on the timeslider", function(done) {
|
|
||||||
|
|
||||||
|
// Disabled as jquery trigger no longer works properly
|
||||||
|
xit("changes the url when clicking on the timeslider", function(done) {
|
||||||
var inner$ = helper.padInner$;
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.padChrome$;
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
||||||
|
@ -80,7 +84,6 @@ describe("timeslider", function(){
|
||||||
var $sliderBar = timeslider$('#ui-slider-bar');
|
var $sliderBar = timeslider$('#ui-slider-bar');
|
||||||
|
|
||||||
var latestContents = timeslider$('#padcontent').text();
|
var latestContents = timeslider$('#padcontent').text();
|
||||||
|
|
||||||
var oldUrl = $('#iframe-container iframe')[0].contentWindow.location.hash;
|
var oldUrl = $('#iframe-container iframe')[0].contentWindow.location.hash;
|
||||||
|
|
||||||
// Click somewhere on the timeslider
|
// Click somewhere on the timeslider
|
||||||
|
@ -111,6 +114,7 @@ describe("timeslider", function(){
|
||||||
var oldLength = inner$('body').text().length + newLines / 2;
|
var oldLength = inner$('body').text().length + newLines / 2;
|
||||||
expect( oldLength ).to.not.eql( 0 );
|
expect( oldLength ).to.not.eql( 0 );
|
||||||
inner$("div").first().sendkeys('a');
|
inner$("div").first().sendkeys('a');
|
||||||
|
var timeslider$;
|
||||||
|
|
||||||
// wait for our additional revision to be added
|
// wait for our additional revision to be added
|
||||||
helper.waitFor(function(){
|
helper.waitFor(function(){
|
||||||
|
@ -140,6 +144,7 @@ describe("timeslider", function(){
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("checks the export url", function(done) {
|
it("checks the export url", function(done) {
|
||||||
var inner$ = helper.padInner$;
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.padChrome$;
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
|
@ -44,7 +44,7 @@ describe("undo button", function(){
|
||||||
var modifiedValue = $firstTextElement.text(); // get the modified value
|
var modifiedValue = $firstTextElement.text(); // get the modified value
|
||||||
expect(modifiedValue).not.to.be(originalValue); // expect the value to change
|
expect(modifiedValue).not.to.be(originalValue); // expect the value to change
|
||||||
|
|
||||||
if(inner$.browser.mozilla){ // if it's a mozilla browser
|
if(inner$(window)[0].bowser.firefox){ // if it's a mozilla browser
|
||||||
var evtType = "keypress";
|
var evtType = "keypress";
|
||||||
}else{
|
}else{
|
||||||
var evtType = "keydown";
|
var evtType = "keydown";
|
||||||
|
|
Loading…
Reference in a new issue