Skip to content

Commit

Permalink
Add tests and fix yaml-lint code
Browse files Browse the repository at this point in the history
  • Loading branch information
asantos00 committed Jun 4, 2019
1 parent a1438e6 commit 8910f2c
Show file tree
Hide file tree
Showing 4 changed files with 110 additions and 41 deletions.
39 changes: 9 additions & 30 deletions lib/ace/mode/yaml/yaml-lint.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,42 +9,21 @@ var DEFAULT_LINT_OPTION = {
schema: 'DEFAULT_SAFE_SCHEMA'
};

function lint(content, opts) {
function lint(content, opts, cb) {

var options = merge({}, DEFAULT_LINT_OPTION, opts);

return new window.Promise(function(resolve, reject) {
try {
yaml.safeLoad(content, {
schema: yaml[options.schema]
});
resolve();
} catch (e) {
reject(e);
}
});

}

function lintFile(file, opts) {
return new window.Promise(function (resolve, reject) {
fs.readFile(file, 'utf8', function (err, content) {
if (err) {
reject(err);
} else {
lint(content, opts).then(function (result) {
resolve(result);
}).catch(function(e) {
reject(e);
});
}
try {
yaml.safeLoad(content, {
schema: yaml[options.schema]
});
});
cb();
} catch (e) {
cb(e);
}
}

module.exports = {
lint: lint,
lintFile: lintFile
lint: lint
};

},{"fs":1,"js-yaml":3,"lodash.merge":33}],3:[function(require,module,exports){
Expand Down
24 changes: 14 additions & 10 deletions lib/ace/mode/yaml_worker.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,18 +28,22 @@ oop.inherits(YamlWorker, Mirror);
var value = this.doc.getValue();
var errors = [];

lint(value)
.catch(function(error) {
errors.push({
row: error.mark.line,
column: error.mark.column,
text: error.reason,
type: 'error',
raw: error
});

lint(value, {}, function(error) {
if (!error) {
_this.sender.emit("annotate", errors);
return;
}

errors.push({
row: error.mark.line,
column: error.mark.column,
text: error.reason,
type: 'error',
raw: error
});

_this.sender.emit("annotate", errors);
});
};

}).call(YamlWorker.prototype);
Expand Down
85 changes: 85 additions & 0 deletions lib/ace/mode/yaml_worker_test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
/* ***** BEGIN LICENSE BLOCK *****
* Distributed under the BSD license:
*
* Copyright (c) 2010, Ajax.org B.V.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of Ajax.org B.V. nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL AJAX.ORG B.V. BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* ***** END LICENSE BLOCK ***** */

if (typeof process !== "undefined") {
require("amd-loader");
}

define(function(require, exports, module) {
"use strict";

var assert = require("../test/assertions");
var YamlWorker = require("./yaml_worker").YamlWorker;


module.exports = {
setUp : function() {
this.sender = {
on: function() {},
callback: function(data, id) {
this.data = data;
},
events: [],
emit: function(type, e) {
this.events.push([type, e]);
}
};
},

"test check for syntax error": function() {
var worker = new YamlWorker(this.sender);
worker.setValue('test: "test');
worker.deferredUpdate.call();

var error = this.sender.events[0][1][0];
assert.equal(error.text, 'unexpected end of the stream within a double quoted scalar');
assert.equal(error.type, "error");
assert.equal(error.row, 1);
assert.equal(error.column, 0);
},

"test unknown tag": function() {
var worker = new YamlWorker(this.sender);
worker.setValue("- !<foo#bar> bar");
worker.deferredUpdate.call();

var error = this.sender.events[0][1][0];
assert.equal(error.text, 'unknown tag !<foo#bar>');
assert.equal(error.type, "error");
assert.equal(error.row, 0);
assert.equal(error.column, 16);
}
};

});

if (typeof module !== "undefined" && module === require.main) {
require("asyncjs").test.testcase(module.exports).exec();
}
3 changes: 2 additions & 1 deletion lib/ace/test/all_browser.js
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,8 @@ var testNames = [
"ace/token_iterator_test",
"ace/tokenizer_test",
"ace/undomanager_test",
"ace/virtual_renderer_test"
"ace/virtual_renderer_test",
"ace/mode/yaml_worker_test"
];

var html = ["<a href='?'>all tests</a><br>"];
Expand Down

0 comments on commit 8910f2c

Please sign in to comment.