mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-24 16:40:11 -05:00
Escape variable name in XML
This commit is contained in:
parent
98b92be2d7
commit
8eee92d41a
2 changed files with 112 additions and 1 deletions
|
@ -4,6 +4,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const uid = require('../util/uid');
|
const uid = require('../util/uid');
|
||||||
|
const xmlEscape = require('../util/xml-escape');
|
||||||
|
|
||||||
class Variable {
|
class Variable {
|
||||||
/**
|
/**
|
||||||
|
@ -36,7 +37,7 @@ class Variable {
|
||||||
toXML (isLocal) {
|
toXML (isLocal) {
|
||||||
isLocal = (isLocal === true);
|
isLocal = (isLocal === true);
|
||||||
return `<variable type="${this.type}" id="${this.id}" islocal="${isLocal
|
return `<variable type="${this.type}" id="${this.id}" islocal="${isLocal
|
||||||
}" iscloud="${this.isCloud}">${this.name}</variable>`;
|
}" iscloud="${this.isCloud}">${xmlEscape(this.name)}</variable>`;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
110
test/unit/engine_variable.js
Normal file
110
test/unit/engine_variable.js
Normal file
|
@ -0,0 +1,110 @@
|
||||||
|
const test = require('tap').test;
|
||||||
|
const Variable = require('../../src/engine/variable');
|
||||||
|
const htmlparser = require('htmlparser2');
|
||||||
|
|
||||||
|
test('spec', t => {
|
||||||
|
t.type(typeof Variable.SCALAR_TYPE, typeof Variable.LIST_TYPE);
|
||||||
|
t.type(typeof Variable.SCALAR_TYPE, typeof Variable.BROADCAST_MESSAGE_TYPE);
|
||||||
|
|
||||||
|
const varId = 'varId';
|
||||||
|
const varName = 'varName';
|
||||||
|
const varIsCloud = false;
|
||||||
|
let v = new Variable(
|
||||||
|
varId,
|
||||||
|
varName,
|
||||||
|
Variable.SCALAR_TYPE,
|
||||||
|
varIsCloud
|
||||||
|
);
|
||||||
|
|
||||||
|
t.type(Variable, 'function');
|
||||||
|
t.type(v, 'object');
|
||||||
|
t.ok(v instanceof Variable);
|
||||||
|
|
||||||
|
t.equal(v.id, varId);
|
||||||
|
t.equal(v.name, varName);
|
||||||
|
t.equal(v.type, Variable.SCALAR_TYPE);
|
||||||
|
t.type(v.value, 'number');
|
||||||
|
t.equal(v.isCloud, varIsCloud);
|
||||||
|
|
||||||
|
t.type(v.toXML, 'function');
|
||||||
|
|
||||||
|
v = new Variable(
|
||||||
|
varId,
|
||||||
|
varName,
|
||||||
|
Variable.LIST_TYPE,
|
||||||
|
varIsCloud
|
||||||
|
);
|
||||||
|
t.ok(Array.isArray(v.value));
|
||||||
|
|
||||||
|
v = new Variable(
|
||||||
|
varId,
|
||||||
|
varName,
|
||||||
|
Variable.BROADCAST_MESSAGE_TYPE,
|
||||||
|
varIsCloud
|
||||||
|
);
|
||||||
|
t.equal(v.value, 'varName');
|
||||||
|
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('toXML', t => {
|
||||||
|
const varId = 'varId';
|
||||||
|
const varName = 'varName';
|
||||||
|
const varIsCloud = false;
|
||||||
|
const varIsLocal = false;
|
||||||
|
const v = new Variable(
|
||||||
|
varId,
|
||||||
|
varName,
|
||||||
|
Variable.SCALAR_TYPE,
|
||||||
|
varIsCloud
|
||||||
|
);
|
||||||
|
|
||||||
|
const parser = new htmlparser.Parser({
|
||||||
|
onopentag: function (name, attribs){
|
||||||
|
if (name === 'variable'){
|
||||||
|
t.equal(attribs.type, Variable.SCALAR_TYPE);
|
||||||
|
t.equal(attribs.id, varId);
|
||||||
|
t.equal(attribs.iscloud, varIsCloud.toString());
|
||||||
|
t.equal(attribs.islocal, varIsLocal.toString());
|
||||||
|
}
|
||||||
|
},
|
||||||
|
ontext: function (text){
|
||||||
|
t.equal(text, varName);
|
||||||
|
}
|
||||||
|
}, {decodeEntities: false});
|
||||||
|
parser.write(v.toXML(false));
|
||||||
|
parser.end();
|
||||||
|
|
||||||
|
t.end();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('escape variable name for XML', t => {
|
||||||
|
const varId = 'varId';
|
||||||
|
const varName = '<>&\'"';
|
||||||
|
const varIsCloud = false;
|
||||||
|
const varIsLocal = false;
|
||||||
|
const v = new Variable(
|
||||||
|
varId,
|
||||||
|
varName,
|
||||||
|
Variable.SCALAR_TYPE,
|
||||||
|
varIsCloud
|
||||||
|
);
|
||||||
|
|
||||||
|
const parser = new htmlparser.Parser({
|
||||||
|
onopentag: function (name, attribs){
|
||||||
|
if (name === 'variable'){
|
||||||
|
t.equal(attribs.type, Variable.SCALAR_TYPE);
|
||||||
|
t.equal(attribs.id, varId);
|
||||||
|
t.equal(attribs.iscloud, varIsCloud.toString());
|
||||||
|
t.equal(attribs.islocal, varIsLocal.toString());
|
||||||
|
}
|
||||||
|
},
|
||||||
|
ontext: function (text){
|
||||||
|
t.equal(text, '<>&'"');
|
||||||
|
}
|
||||||
|
}, {decodeEntities: false});
|
||||||
|
parser.write(v.toXML(false));
|
||||||
|
parser.end();
|
||||||
|
|
||||||
|
t.end();
|
||||||
|
});
|
Loading…
Reference in a new issue