debugging File shim

This commit is contained in:
d98762625 2019-03-14 08:27:06 +00:00
parent 14d591caa1
commit d080c5dd14
7 changed files with 23 additions and 20 deletions

View file

@ -44,10 +44,6 @@ class Dish {
if (dishOrInput && if (dishOrInput &&
dishOrInput.hasOwnProperty("value") && dishOrInput.hasOwnProperty("value") &&
dishOrInput.hasOwnProperty("type")) { dishOrInput.hasOwnProperty("type")) {
console.log('first setting');
console.log(dishOrInput);
console.log(dishOrInput.constructor.name);
console.log(dishOrInput.value);
this.set(dishOrInput.value, dishOrInput.type); this.set(dishOrInput.value, dishOrInput.type);
// input and type defined separately // input and type defined separately
} else if (dishOrInput && type) { } else if (dishOrInput && type) {
@ -103,8 +99,6 @@ class Dish {
* @returns {string} The data type as a string. * @returns {string} The data type as a string.
*/ */
static enumLookup(typeEnum) { static enumLookup(typeEnum) {
console.trace('enumLookup');
console.log('type ' + typeEnum);
switch (typeEnum) { switch (typeEnum) {
case Dish.BYTE_ARRAY: case Dish.BYTE_ARRAY:
return "byteArray"; return "byteArray";
@ -180,16 +174,11 @@ class Dish {
type = Dish.typeEnum(type); type = Dish.typeEnum(type);
} }
console.log('Dish setting:');
console.log(value);
console.log(type);
log.debug("Dish type: " + Dish.enumLookup(type)); log.debug("Dish type: " + Dish.enumLookup(type));
this.value = value; this.value = value;
this.type = type; this.type = type;
if (!this.valid()) { if (!this.valid()) {
console.log('invalid!');
const sample = Utils.truncate(JSON.stringify(this.value), 13); const sample = Utils.truncate(JSON.stringify(this.value), 13);
throw new DishError(`Data is not a valid ${Dish.enumLookup(type)}: ${sample}`); throw new DishError(`Data is not a valid ${Dish.enumLookup(type)}: ${sample}`);
} }
@ -231,8 +220,6 @@ class Dish {
// All values can be serialised in some manner, so we return true in all cases // All values can be serialised in some manner, so we return true in all cases
return true; return true;
case Dish.FILE: case Dish.FILE:
console.log("Validating on file");
console.log(this.value instanceof File);
return this.value instanceof File; return this.value instanceof File;
case Dish.LIST_FILE: case Dish.LIST_FILE:
return this.value instanceof Array && return this.value instanceof Array &&
@ -349,13 +336,13 @@ class Dish {
// Node environment => translate is sync // Node environment => translate is sync
if (Utils.isNode()) { if (Utils.isNode()) {
console.log('_translate toType:'); console.log('Running in node');
console.log(toType);
this._toByteArray(); this._toByteArray();
this._fromByteArray(toType, notUTF8); this._fromByteArray(toType, notUTF8);
// Browser environment => translate is async // Browser environment => translate is async
} else { } else {
console.log('Running in browser');
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
this._toByteArray() this._toByteArray()
.then(() => this.type = Dish.BYTE_ARRAY) .then(() => this.type = Dish.BYTE_ARRAY)
@ -404,7 +391,6 @@ class Dish {
}; };
try { try {
console.log("_tyByteArray this.type: " + this.type);
return toByteArrayFuncs[Utils.isNode() && "node" || "browser"][this.type](); return toByteArrayFuncs[Utils.isNode() && "node" || "browser"][this.type]();
} catch (err) { } catch (err) {
throw new DishError(`Error translating from ${Dish.enumLookup(this.type)} to byteArray: ${err}`); throw new DishError(`Error translating from ${Dish.enumLookup(this.type)} to byteArray: ${err}`);

View file

@ -967,6 +967,10 @@ class Utils {
throw new TypeError("Browser environment cannot support readFileSync"); throw new TypeError("Browser environment cannot support readFileSync");
} }
console.log('readFileSync:');
console.log(file);
console.log(Buffer.from(file.data).toString());
return Buffer.from(file.data).buffer; return Buffer.from(file.data).buffer;
} }

View file

@ -19,9 +19,12 @@ class DishFile extends DishTranslationType {
static toByteArray() { static toByteArray() {
DishFile.checkForValue(this.value); DishFile.checkForValue(this.value);
if (Utils.isNode()) { if (Utils.isNode()) {
console.log("valie: "); console.log('toByteArray original value:');
console.log(this.value); console.log(this.value);
// this.value = Utils.readFileSync(this.value);
this.value = Array.prototype.slice.call(Utils.readFileSync(this.value)); this.value = Array.prototype.slice.call(Utils.readFileSync(this.value));
console.log('toByteArray value:');
console.log(this.value);
} else { } else {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
Utils.readFile(this.value) Utils.readFile(this.value)
@ -40,6 +43,8 @@ class DishFile extends DishTranslationType {
static fromByteArray() { static fromByteArray() {
DishFile.checkForValue(this.value); DishFile.checkForValue(this.value);
this.value = new File(this.value, "unknown"); this.value = new File(this.value, "unknown");
console.log('from Byte array');
console.log(this.value);
} }
} }

View file

@ -17,8 +17,10 @@ class DishString extends DishTranslationType {
* convert the given value to a ByteArray * convert the given value to a ByteArray
*/ */
static toByteArray() { static toByteArray() {
console.log('string to byte array');
DishString.checkForValue(this.value); DishString.checkForValue(this.value);
this.value = this.value ? Utils.strToByteArray(this.value) : []; this.value = this.value ? Utils.strToByteArray(this.value) : [];
console.log(this.value);
} }
/** /**

View file

@ -132,6 +132,8 @@ class Tar extends Operation {
tarball.writeBytes(input); tarball.writeBytes(input);
tarball.writeEndBlocks(); tarball.writeEndBlocks();
console.log('Tar bytes');
console.log(tarball.bytes);
return new File([new Uint8Array(tarball.bytes)], args[0]); return new File([new Uint8Array(tarball.bytes)], args[0]);
} }

View file

@ -24,10 +24,16 @@ class File {
* @param {Object} stats (optional) - file stats e.g. lastModified * @param {Object} stats (optional) - file stats e.g. lastModified
*/ */
constructor(data, name="", stats={}) { constructor(data, name="", stats={}) {
this.data = Buffer.from(data); // Look at File API definition to see how to handle this.
this.data = Buffer.from(data[0]);
this.name = name; this.name = name;
this.lastModified = stats.lastModified || Date.now(); this.lastModified = stats.lastModified || Date.now();
this.type = stats.type || mime.getType(this.name); this.type = stats.type || mime.getType(this.name);
console.log('File constructor');
console.log(typeof data);
console.log(data);
console.log(this.data);
} }
/** /**

View file

@ -197,8 +197,6 @@ export function wrap(OpClass) {
wrapped = (input, args=null) => { wrapped = (input, args=null) => {
const {transformedInput, transformedArgs} = prepareOp(opInstance, input, args); const {transformedInput, transformedArgs} = prepareOp(opInstance, input, args);
const result = opInstance.run(transformedInput, transformedArgs); const result = opInstance.run(transformedInput, transformedArgs);
console.log('Result:');
console.log(result);
return new NodeDish({ return new NodeDish({
value: result, value: result,
type: opInstance.outputType, type: opInstance.outputType,