2015-02-10 19:41:24 +00:00
|
|
|
/*global describe it before after bar*/
|
|
|
|
|
|
|
|
"use client";
|
|
|
|
|
|
|
|
require(["lib/architect/architect", "lib/chai/chai"], function (architect, chai) {
|
|
|
|
var expect = chai.expect;
|
|
|
|
|
|
|
|
expect.setupArchitectTest([
|
|
|
|
{
|
|
|
|
packagePath: "plugins/c9.core/c9",
|
|
|
|
workspaceId: "ubuntu/ip-10-35-77-180",
|
|
|
|
startdate: new Date(),
|
|
|
|
debug: true,
|
|
|
|
hosted: true,
|
|
|
|
local: false,
|
|
|
|
davPrefix: "/"
|
|
|
|
},
|
|
|
|
|
|
|
|
"plugins/c9.core/ext",
|
|
|
|
"plugins/c9.core/http-xhr",
|
|
|
|
"plugins/c9.core/util",
|
|
|
|
"plugins/c9.ide.ui/lib_apf",
|
|
|
|
"plugins/c9.ide.ui/menus",
|
|
|
|
{
|
|
|
|
packagePath: "plugins/c9.core/settings",
|
|
|
|
settings: "default",
|
|
|
|
testing: true
|
|
|
|
},
|
|
|
|
"plugins/c9.core/api.js",
|
|
|
|
{
|
|
|
|
packagePath: "plugins/c9.ide.ui/ui",
|
|
|
|
staticPrefix: "plugins/c9.ide.ui"
|
|
|
|
},
|
|
|
|
"plugins/c9.ide.editors/document",
|
|
|
|
"plugins/c9.ide.editors/undomanager",
|
|
|
|
{
|
|
|
|
packagePath: "plugins/c9.ide.editors/editors",
|
|
|
|
defaultEditor: "ace"
|
|
|
|
},
|
|
|
|
"plugins/c9.ide.editors/editor",
|
|
|
|
"plugins/c9.ide.editors/tabmanager",
|
|
|
|
"plugins/c9.ide.ui/focus",
|
|
|
|
"plugins/c9.ide.editors/pane",
|
|
|
|
"plugins/c9.ide.editors/tab",
|
|
|
|
{
|
|
|
|
packagePath: "plugins/c9.ide.ace/ace",
|
|
|
|
staticPrefix: "plugins/c9.ide.layout.classic"
|
|
|
|
},
|
|
|
|
"plugins/c9.ide.keys/commands",
|
|
|
|
"plugins/c9.fs/proc",
|
|
|
|
"plugins/c9.vfs.client/vfs_client",
|
|
|
|
"plugins/c9.vfs.client/endpoint",
|
|
|
|
"plugins/c9.ide.auth/auth",
|
|
|
|
"plugins/c9.fs/fs",
|
|
|
|
|
|
|
|
"plugins/c9.ide.dialog/dialog",
|
|
|
|
"plugins/c9.ide.dialog.common/alert",
|
|
|
|
"plugins/c9.ide.dialog.common/alert_internal",
|
|
|
|
|
|
|
|
// Mock plugins
|
|
|
|
{
|
|
|
|
consumes: ["apf", "ui", "Plugin"],
|
|
|
|
provides: [
|
|
|
|
"commands", "menus", "layout", "watcher",
|
|
|
|
"save", "preferences", "anims", "clipboard", "auth.bootstrap",
|
|
|
|
"info", "dialog.error", "threewaymerge", "error_handler"
|
|
|
|
],
|
|
|
|
setup: expect.html.mocked
|
|
|
|
},
|
|
|
|
{
|
|
|
|
consumes: ["tabManager", "ace", "commands"],
|
|
|
|
provides: [],
|
|
|
|
setup: main
|
|
|
|
}
|
|
|
|
], architect);
|
|
|
|
|
|
|
|
function main(options, imports, register) {
|
|
|
|
var tabs = imports.tabManager;
|
|
|
|
var ace = imports.ace;
|
|
|
|
var commands = imports.commands;
|
|
|
|
|
|
|
|
function getTabHtml(tab) {
|
|
|
|
return tab.pane.aml.getPage("editor::" + tab.editorType).$ext;
|
|
|
|
}
|
|
|
|
|
|
|
|
expect.html.setConstructor(function(tab) {
|
|
|
|
if (tab && typeof tab == "object")
|
|
|
|
return getTabHtml(tab);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('ace', function() {
|
|
|
|
before(function(done) {
|
|
|
|
apf.config.setProperty("allow-select", false);
|
|
|
|
apf.config.setProperty("allow-blur", false);
|
|
|
|
|
|
|
|
bar.$ext.style.background = "rgba(220, 220, 220, 0.93)";
|
|
|
|
bar.$ext.style.position = "fixed";
|
|
|
|
bar.$ext.style.left = "20px";
|
|
|
|
bar.$ext.style.width = "1000px";
|
|
|
|
bar.$ext.style.bottom = "20px";
|
|
|
|
bar.$ext.style.height = "33%";
|
|
|
|
|
|
|
|
document.body.style.marginBottom = "33%";
|
|
|
|
|
|
|
|
tabs.once("ready", function(){
|
|
|
|
tabs.getPanes()[0].focus();
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("open", function(){
|
|
|
|
this.timeout(10000);
|
|
|
|
|
|
|
|
it('should open a pane with just an editor', function(done) {
|
|
|
|
tabs.openFile("/file.txt", function(err, tab) {
|
|
|
|
expect(tabs.getTabs()).length(1);
|
|
|
|
|
|
|
|
expect(tab.document.title).equals("file.txt");
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
it('should handle multiple documents in the same pane', function(done) {
|
|
|
|
tabs.openFile("/listing.json", function(err, tab) {
|
|
|
|
expect(tabs.getTabs()).length(2);
|
|
|
|
|
|
|
|
tab.activate();
|
|
|
|
|
|
|
|
var doc = tab.document;
|
|
|
|
expect(doc.title).match(new RegExp("listing.json"));
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
describe("clear(), getState() and setState()", function(){
|
|
|
|
var state, info = {};
|
|
|
|
|
|
|
|
it('should retrieve the state', function(done) {
|
|
|
|
// @todo make sure ace has a selection and scrolltop / left
|
|
|
|
|
|
|
|
state = tabs.getState();
|
|
|
|
info.pages = tabs.getTabs().map(function(tab) {
|
|
|
|
return tab.path || tab.id;
|
|
|
|
});
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should clear all tabs and pages', function(done) {
|
|
|
|
tabs.getPanes()[0];
|
|
|
|
var pages = tabs.getTabs();
|
|
|
|
tabs.clear(true, true); //Soft clear, not unloading the pages
|
|
|
|
expect(tabs.getTabs(), "pages").length(0);
|
|
|
|
expect(tabs.getPanes(), "tabManager").length(0);
|
|
|
|
//expect(pane.getTabs(), "aml").length(0);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should restore the state', function(done) {
|
|
|
|
// @todo make sure the selection and scrolltop / left is preserved
|
|
|
|
|
|
|
|
tabs.setState(state, false, function(err) {
|
|
|
|
if (err) throw err.message;
|
|
|
|
});
|
|
|
|
var l = info.pages.length;
|
|
|
|
expect(tabs.getTabs()).length(l);
|
|
|
|
expect(tabs.getPanes()[0].getTabs()).length(l);
|
|
|
|
expect(tabs.focussedTab.pane.getTabs()).length(l);
|
|
|
|
|
|
|
|
expect(tabs.getTabs().map(function(tab) {
|
|
|
|
return tab.path || tab.id;
|
|
|
|
})).to.deep.equal(info.pages);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should jump to on an already loaded file', function(done) {
|
|
|
|
var tab = tabs.focussedTab;
|
|
|
|
tab.document.setState({
|
|
|
|
ace: {
|
|
|
|
jump: {
|
|
|
|
row: 3,
|
|
|
|
column: 10
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
var cursor = tab.editor.ace.getCursorPosition();
|
|
|
|
expect(cursor.row).equals(3);
|
|
|
|
expect(cursor.column).equals(10);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
describe("split(), pane.unload()", function(){
|
|
|
|
it('should split a pane horizontally, making the existing pane the left one', function(done) {
|
|
|
|
var pane = tabs.focussedTab.pane;
|
|
|
|
var righttab = pane.hsplit(true);
|
|
|
|
tabs.focussedTab.attachTo(righttab);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should remove the left pane from a horizontal split', function(done) {
|
|
|
|
var pane = tabs.getPanes()[0];
|
|
|
|
var tab = tabs.getPanes()[1].getTab();
|
|
|
|
pane.unload();
|
|
|
|
expect(tabs.getPanes()).length(1);
|
|
|
|
expect(tabs.getTabs()).length(2);
|
|
|
|
tabs.focusTab(tab);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
describe("focus(), blur()", function(){
|
|
|
|
it('should get the right className and take keyboard input when focussed', function(done) {
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should get the right className and don\'t take any keyboard input when blurred', function(done) {
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
describe("customType", function(){
|
|
|
|
it('should remember custom types set on known extensions', function(done) {
|
|
|
|
|
|
|
|
//@todo check if it is recorded in settings
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should remember custom types set on unknown extensions', function(done) {
|
|
|
|
|
|
|
|
//@todo check if it is recorded in settings
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function render(){
|
|
|
|
var editor = tabs.focussedTab.editor;
|
|
|
|
var changes = editor.ace.renderer.$loop.changes;
|
|
|
|
editor.ace.renderer.$loop.changes = 0;
|
|
|
|
editor.ace.renderer.$renderChanges(changes, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
describe("setOption()", function(){
|
|
|
|
this.timeout(10000);
|
|
|
|
var lineHeight, session, editor, charWidth, doc;
|
|
|
|
|
|
|
|
before(function(done) {
|
|
|
|
doc = tabs.focussedTab.document;
|
|
|
|
editor = doc.editor;
|
|
|
|
session = doc.getSession().session;
|
|
|
|
lineHeight = doc.editor.ace.renderer.lineHeight;
|
|
|
|
charWidth =doc.editor.ace.renderer.characterWidth;
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should change a theme', function(done) {
|
|
|
|
var theme = "ace/theme/textmate";
|
|
|
|
editor.ace.renderer.on("themeLoaded", function me(e) {
|
|
|
|
if (e.theme.cssClass != "ace-tm") return;
|
|
|
|
|
|
|
|
editor.ace.renderer.removeListener("themeLoaded", me);
|
|
|
|
expect.html(getTabHtml(tabs.focussedTab).childNodes[1]).className("ace-tm");
|
|
|
|
|
|
|
|
ace.once("themeChange", function(){
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
ace.setTheme("ace/theme/tomorrow_night_bright");
|
|
|
|
});
|
|
|
|
ace.setTheme(theme);
|
|
|
|
});
|
|
|
|
it('should allow setting useWrapMode', function(done) {
|
2015-12-02 15:07:25 +00:00
|
|
|
var charW = editor.ace.renderer.layerConfig.characterWidth;
|
|
|
|
expect(charW).to.ok;
|
|
|
|
bar.$ext.style.width = 150 * charW + "px"
|
|
|
|
|
|
|
|
doc.value = Array(17).join("a very long string to be wrapped ");
|
2015-02-10 19:41:24 +00:00
|
|
|
|
|
|
|
render();
|
|
|
|
|
2015-12-02 15:07:25 +00:00
|
|
|
|
|
|
|
bar.$ext.style.width = "1000px";
|
|
|
|
|
2015-02-10 19:41:24 +00:00
|
|
|
expect(document.querySelector(".ace_gutter-cell").offsetHeight).to.equal(lineHeight);
|
|
|
|
editor.setOption("useWrapMode", true);
|
|
|
|
|
|
|
|
render();
|
|
|
|
|
|
|
|
expect(Math.ceil(document.querySelector(".ace_gutter-cell").offsetHeight)).to.equal(lineHeight * 7);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting wrapToView', function(done) {
|
|
|
|
expect(document.querySelector(".ace_gutter-cell").offsetHeight).to.equal(lineHeight * 7);
|
|
|
|
editor.setOption("wrapToView", true);
|
|
|
|
|
|
|
|
render();
|
|
|
|
|
|
|
|
expect(document.querySelector(".ace_gutter-cell").offsetHeight).to.equal(lineHeight * 4);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting wrapBehavioursEnabled', function(done) {
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting newLineMode', function(done) {
|
|
|
|
editor.setOption("newLineMode", "windows");
|
|
|
|
doc.value = "line1\nline2\nline3\nline4\nline5";
|
|
|
|
|
|
|
|
render();
|
|
|
|
|
|
|
|
expect(session.getValue(session.doc.$fsNewLine)).to.match(/\r/);
|
|
|
|
|
|
|
|
editor.setOption("newLineMode", "unix");
|
|
|
|
|
|
|
|
expect(session.getValue()).to.not.match(/\r/);
|
|
|
|
|
|
|
|
editor.setOption("newLineMode", "auto");
|
|
|
|
|
|
|
|
expect(session.getValue()).to.not.match(/\r/);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting tabSize', function(done) {
|
|
|
|
doc.value = "\tline1\n\t\tline2\n\t\tline3\n\tline4\nline5";
|
|
|
|
render();
|
|
|
|
|
|
|
|
editor.setOption("tabSize", 4);
|
|
|
|
|
|
|
|
render();
|
|
|
|
expect.html(doc.tab, "tabSize: 4").text(/\s{8}/);
|
|
|
|
|
|
|
|
editor.setOption("tabSize", 8);
|
|
|
|
render();
|
|
|
|
|
|
|
|
expect.html(doc.tab, "tabSize: 8").text(/\s{16}/);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting useSoftTabs', function(done) {
|
|
|
|
doc.value = " line1\n line2\n line3\n line4\nline5";
|
|
|
|
render();
|
|
|
|
|
|
|
|
editor.setOption("tabSize", 4);
|
|
|
|
editor.setOption("useSoftTabs", true);
|
|
|
|
|
|
|
|
editor.ace.moveCursorTo(1, 0);
|
|
|
|
// command isAvailable works only if editor is focussed
|
|
|
|
// which might break the test when debugger is focussed
|
|
|
|
editor.ace.isFocused = function() {return true};
|
|
|
|
commands.exec("gotoright", editor, null,
|
|
|
|
document.createEvent("KeyboardEvent"));
|
|
|
|
delete editor.ace.isFocused;
|
|
|
|
|
|
|
|
expect(editor.ace.getCursorPosition()).deep.equal({row:1, column:4});
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting fontSize', function(done) {
|
|
|
|
expect(document.querySelector(".ace_gutter-cell").offsetHeight).equal(lineHeight);
|
|
|
|
|
|
|
|
editor.setOption("fontSize", 30);
|
|
|
|
|
|
|
|
expect(document.querySelector(".ace_gutter-cell").offsetHeight).gt(lineHeight);
|
|
|
|
|
|
|
|
editor.setOption("fontSize", 12);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting fontFamily', function(done) {
|
|
|
|
editor.setOption("fontFamily", "Courier New");
|
|
|
|
render();
|
|
|
|
|
|
|
|
expect(editor.ace.container.style.fontFamily).to.match(/Courier New/);
|
|
|
|
|
|
|
|
var font = "Monaco, Menlo, 'Ubuntu Mono', Consolas, source-code-pro, monospace";
|
|
|
|
editor.setOption("fontFamily", font);
|
|
|
|
render();
|
|
|
|
|
|
|
|
expect(editor.ace.container.style.fontFamily).to.match(/Monaco/)
|
|
|
|
.and.to.not.match(/Courier/);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting selectionStyle', function(done) {
|
|
|
|
session.getSelection().setSelectionRange({
|
|
|
|
start: {
|
|
|
|
row: 0,
|
|
|
|
column: 0
|
|
|
|
},
|
|
|
|
end: {
|
|
|
|
row: 4,
|
|
|
|
column: 0
|
|
|
|
}
|
|
|
|
}, false);
|
|
|
|
|
|
|
|
editor.setOption("selectionStyle", "text");
|
|
|
|
render();
|
|
|
|
|
|
|
|
function selectionElementWidth() {
|
|
|
|
var el = document.querySelectorAll(".ace_selection")[0];
|
|
|
|
return el.getBoundingClientRect().width;
|
|
|
|
}
|
|
|
|
|
|
|
|
var chars = selectionElementWidth() / charWidth;
|
|
|
|
expect(chars - 10).to.lt(1/100);
|
|
|
|
|
|
|
|
editor.setOption("selectionStyle", "line");
|
|
|
|
render();
|
|
|
|
|
|
|
|
chars = selectionElementWidth() / charWidth;
|
|
|
|
expect(chars).to.gt(10);
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting highlightActiveLine', function(done) {
|
|
|
|
session.getSelection().clearSelection();
|
|
|
|
|
|
|
|
editor.setOption("highlightActiveLine", false);
|
|
|
|
render();
|
|
|
|
expect(document.querySelector(".ace_active-line")).to.not.ok;
|
|
|
|
|
|
|
|
editor.setOption("highlightActiveLine", true);
|
|
|
|
render();
|
|
|
|
expect(document.querySelector(".ace_active-line")).to.ok;
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting highlightGutterLine', function(done) {
|
|
|
|
editor.setOption("highlightGutterLine", false);
|
|
|
|
render();
|
|
|
|
expect(document.querySelector(".ace_gutter-active-line").offsetHeight).to.not.ok;
|
|
|
|
|
|
|
|
editor.setOption("highlightGutterLine", true);
|
|
|
|
render();
|
|
|
|
expect(document.querySelector(".ace_gutter-active-line").offsetHeight).to.ok;
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting showInvisibles', function(done) {
|
|
|
|
editor.setOption("showInvisibles", true);
|
|
|
|
render();
|
|
|
|
expect(document.querySelectorAll(".ace_invisible").length).ok;
|
|
|
|
editor.setOption("showInvisibles", false);
|
|
|
|
render();
|
|
|
|
expect(document.querySelectorAll(".ace_invisible").length).not.ok;
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting showPrintMargin', function(done) {
|
|
|
|
editor.setOption("showPrintMargin", false);
|
|
|
|
expect(document.querySelector(".ace_print-margin").style.visibility).equal("hidden");
|
|
|
|
editor.setOption("showPrintMargin", true);
|
|
|
|
expect(document.querySelector(".ace_print-margin").style.visibility).equal("visible");
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting printMarginColumn', function(done) {
|
|
|
|
editor.setOption("printMarginColumn", 100);
|
|
|
|
var value = Math.floor(parseInt(document.querySelector(".ace_print-margin").style.left) / charWidth);
|
|
|
|
expect(value).equal(100);
|
|
|
|
editor.setOption("printMarginColumn", 80);
|
|
|
|
var value = Math.floor(parseInt(document.querySelector(".ace_print-margin").style.left) / charWidth);
|
|
|
|
expect(value).equal(80);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting displayIndentGuides', function(done) {
|
|
|
|
editor.setOption("displayIndentGuides", false);
|
|
|
|
render();
|
|
|
|
expect(document.querySelector(".ace_indent-guide")).to.not.ok;
|
|
|
|
editor.setOption("displayIndentGuides", true);
|
|
|
|
render();
|
|
|
|
expect(document.querySelector(".ace_indent-guide")).to.ok;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting behavioursEnabled', function(done) {
|
|
|
|
editor.setOption("behavioursEnabled", false);
|
|
|
|
doc.value = "test";
|
|
|
|
render();
|
|
|
|
editor.ace.moveCursorTo(0, 4);
|
|
|
|
render();
|
|
|
|
editor.ace.insert("(");
|
|
|
|
render();
|
|
|
|
expect(doc.value).to.equal("test(");
|
|
|
|
|
|
|
|
editor.setOption("behavioursEnabled", true);
|
|
|
|
doc.value = "test";
|
|
|
|
render();
|
|
|
|
editor.ace.moveCursorTo(0, 4);
|
|
|
|
render();
|
|
|
|
editor.ace.insert("(")
|
|
|
|
render();
|
|
|
|
expect(doc.value).to.equal("test()");
|
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting showGutter', function(done) {
|
|
|
|
editor.setOption("showGutter", false);
|
|
|
|
expect.html(document.querySelector(".ace_gutter")).not.visible;
|
|
|
|
editor.setOption("showGutter", true);
|
|
|
|
expect.html(document.querySelector(".ace_gutter")).visible;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting showFoldWidgets', function(done) {
|
|
|
|
doc.value = "function(){\n\t\n}";
|
|
|
|
editor.setOption("showFoldWidgets", false);
|
|
|
|
render();
|
|
|
|
expect.html(document.querySelector(".ace_fold-widget")).not.ok;
|
|
|
|
editor.setOption("showFoldWidgets", true);
|
|
|
|
render();
|
|
|
|
expect.html(document.querySelector(".ace_fold-widget")).ok;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting highlightSelectedWord', function(done) {
|
|
|
|
doc.value = "test\ntest\ntest";
|
|
|
|
session.getSelection().setSelectionRange({
|
|
|
|
start: {
|
|
|
|
row: 0,
|
|
|
|
column: 0
|
|
|
|
},
|
|
|
|
end: {
|
|
|
|
row: 0,
|
|
|
|
column: 4
|
|
|
|
}
|
|
|
|
}, false);
|
|
|
|
editor.setOption("highlightSelectedWord", false);
|
|
|
|
render();
|
|
|
|
expect.html(document.querySelector(".ace_selected-word")).not.ok;
|
|
|
|
editor.setOption("highlightSelectedWord", true);
|
|
|
|
render();
|
|
|
|
expect.html(document.querySelector(".ace_selected-word")).ok;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
it('should allow setting animatedScroll', function(done) {
|
|
|
|
var i = 0;
|
|
|
|
doc.value = Array(100).join("x").split("x").map(function(){return "Line " + i++}).join("\n");
|
|
|
|
render();
|
|
|
|
|
|
|
|
editor.setOption("animatedScroll", false);
|
|
|
|
editor.scrollTo(50, 0);
|
|
|
|
render();
|
|
|
|
expect.html(doc.tab).text("50");
|
|
|
|
|
|
|
|
editor.setOption("animatedScroll", true);
|
|
|
|
editor.scrollTo(0, 0);
|
|
|
|
render();
|
|
|
|
expect.html(doc.tab).text("50");
|
|
|
|
done();
|
|
|
|
});
|
2015-05-08 13:29:59 +00:00
|
|
|
it('should not loose undomanager state', function(done) {
|
|
|
|
var u = editor.activeDocument.undoManager;
|
|
|
|
u.setState({mark: -1, position: -1, stack: []});
|
|
|
|
var state = u.getState();
|
|
|
|
expect(state.mark).to.equal(-1);
|
|
|
|
expect(state.position).to.equal(-1);
|
|
|
|
expect(state.stack.length).to.equal(0);
|
|
|
|
|
|
|
|
u.setState({mark: -2, position: -1, stack: []});
|
|
|
|
state = u.getState();
|
|
|
|
expect(state.mark).to.equal(-2);
|
|
|
|
expect(state.position).to.equal(-1);
|
|
|
|
expect(state.stack.length).to.equal(0);
|
|
|
|
done();
|
|
|
|
});
|
2015-02-10 19:41:24 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
// @todo test split api and menu
|
|
|
|
|
|
|
|
if (!onload.remain) {
|
|
|
|
after(function(done) {
|
|
|
|
tabs.unload();
|
|
|
|
|
|
|
|
document.body.style.marginBottom = "";
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
onload && onload();
|
|
|
|
}
|
|
|
|
});
|