From 52f7476e05ea176aca6aaa795c25459c7e8dff36 Mon Sep 17 00:00:00 2001 From: cachalots Date: Fri, 28 Apr 2023 15:59:40 +0800 Subject: [PATCH 1/2] Fixed: hex parsed as number --- src/main/helpers.js | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/main/helpers.js b/src/main/helpers.js index 724d1b31..512324e4 100644 --- a/src/main/helpers.js +++ b/src/main/helpers.js @@ -18,7 +18,12 @@ import stream from 'stream' import mime from 'mime-types' var Crypto = require('crypto-browserify') const { XMLParser } = require("fast-xml-parser") -const fxp = new XMLParser() +const fxp = new XMLParser({ + numberParseOptions: { + leadingZeros: false, + hex: false, + } +}) const ipaddr = require('ipaddr.js') import { isBrowser } from "browser-or-node" @@ -379,7 +384,7 @@ export function getSourceVersionId(headers={}){ export function sanitizeETag(etag='') { var replaceChars = {'"':'','"':'','"':'','"':'','"':''} return etag.replace(/^("|"|")|("|"|")$/g, m => replaceChars[m]) - + } export const RETENTION_MODES ={ From 295491a280c17020f4a0acc775b05267d64fc427 Mon Sep 17 00:00:00 2001 From: cachalots Date: Fri, 28 Apr 2023 18:03:50 +0800 Subject: [PATCH 2/2] Fixed: hex parsed as number unit test --- src/test/unit/test.js | 29 ++++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/src/test/unit/test.js b/src/test/unit/test.js index c91d3f17..466f4637 100644 --- a/src/test/unit/test.js +++ b/src/test/unit/test.js @@ -20,17 +20,21 @@ import { assert } from 'chai' import Nock from 'nock' import Stream from 'stream' import * as Minio from '../../../dist/main/minio' -import { isValidEndpoint, +import { isValidEndpoint, isValidIP, makeDateLong, makeDateShort,partsRequired, CopySourceOptions, CopyDestinationOptions, isArray, calculateEvenSplits, + parseXml, } from '../../../dist/main/helpers' var Package = require('../../../package.json') +const { XMLParser } = require("fast-xml-parser") +const fxp = new XMLParser() + describe('Helpers', () => { it('should validate for s3 endpoint', () => { assert.equal(isValidEndpoint('s3.amazonaws.com'), true) @@ -44,7 +48,7 @@ describe('Helpers', () => { it('should fail for invalid endpoint characters', () => { assert.equal(isValidEndpoint('111.#2.11'), false) }) - + it('should make date short', () => { let date = new Date('2012-12-03T17:25:36.331Z') @@ -56,6 +60,13 @@ describe('Helpers', () => { assert.equal(makeDateLong(date), '20170811T172634Z') }) + it('should object key equal 0xf2', () => { + let xml = '0xf2' + let xmlobj = parseXml(xml) + let originxmlobj = fxp.parse(xml) + assert.equal(xmlobj.Key, '0xf2') + assert.equal(originxmlobj.Key, '242') + }) // Adopted from minio-go sdk const oneGB =1024 * 1024 * 1024 @@ -72,7 +83,7 @@ describe('Helpers', () => { const maxMultipartPutObjectSize = 1024 * 1024 * 1024 * 1024 * 5 it('Parts Required Test cases ', () =>{ - + const expectedPartsRequiredTestCases = [ {value:0, expected:0}, {value:1, expected:1}, @@ -157,9 +168,9 @@ describe('Helpers', () => { assert.equal(endIndex, expectedSplitsTestCases.expectedEnd) } }) - + }) - + }) describe('CopyConditions', () => { @@ -707,7 +718,7 @@ describe('Client', function() { done() } }) - + }) describe('#removeObject(bucket, object, callback)', () => { @@ -754,7 +765,7 @@ describe('Client', function() { done() } }) - + it('should fail on empty (string) removeOpts', (done) => { try { client.removeObject('hello', 'testRemoveOpts','', function() {}) @@ -1594,7 +1605,7 @@ describe('Client', function() { done() } }) - + }) }) describe('Select Object Content APIs', ()=> { @@ -1644,7 +1655,7 @@ describe('IP Address Validations', ()=>{ it('should validate for valid ip', () => { assert.equal(isValidIP('1.1.1.1'), true) }) - + it('Check list of IPV4 Invalid addresses', () => { const invalidIpv4 = [' 127.0.0.1', '127.0.0.1 ', '127.0.0.1 127.0.0.1', '127.0.0.256', '127.0.0.1//1', '127.0.0.1/0x1', '127.0.0.1/-1', '127.0.0.1/ab', '127.0.0.1/', '127.0.0.256/32', '127.0.0.1/33'] invalidIpv4.map(ip=>{