2025-04-24 13:11:28 +08:00

249 lines
8.5 KiB
JavaScript

'use strict'
const OError = require('@overleaf/o-error')
const { expect } = require('chai')
const assert = require('../../../../storage/lib/assert')
describe('assert', function () {
describe('blobHash', function () {
it('should not throw for valid blob hashes', function () {
expect(() =>
assert.blobHash(
'aad321caf77ca6c5ab09e6c638c237705f93b001',
'should be a blob hash'
)
).to.not.throw()
})
it('should throw for invalid blob hashes', function () {
try {
assert.blobHash('invalid-hash', 'should be a blob hash')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a blob hash')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: 'invalid-hash' })
}
})
it('should throw for string integer blob hashes', function () {
try {
assert.blobHash('123', 'should be a blob hash')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a blob hash')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: '123' })
}
})
})
describe('projectId', function () {
it('should not throw for valid mongo project ids', function () {
expect(() =>
assert.projectId('507f1f77bcf86cd799439011', 'should be a project id')
).to.not.throw()
})
it('should not throw for valid postgres project ids', function () {
expect(() =>
assert.projectId('123456789', 'should be a project id')
).to.not.throw()
})
it('should throw for invalid project ids', function () {
try {
assert.projectId('invalid-id', 'should be a project id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a project id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: 'invalid-id' })
}
})
it('should throw for non-numeric project ids', function () {
try {
assert.projectId('12345x', 'should be a project id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a project id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: '12345x' })
}
})
it('should throw for postgres ids starting with 0', function () {
try {
assert.projectId('0123456', 'should be a project id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a project id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: '0123456' })
}
})
})
describe('chunkId', function () {
it('should not throw for valid mongo chunk ids', function () {
expect(() =>
assert.chunkId('507f1f77bcf86cd799439011', 'should be a chunk id')
).to.not.throw()
})
it('should not throw for valid postgres chunk ids', function () {
expect(() =>
assert.chunkId('123456789', 'should be a chunk id')
).to.not.throw()
})
it('should throw for invalid chunk ids', function () {
try {
assert.chunkId('invalid-id', 'should be a chunk id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a chunk id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: 'invalid-id' })
}
})
it('should throw for integer chunk ids', function () {
try {
assert.chunkId(12345, 'should be a chunk id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a chunk id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: 12345 })
}
})
})
describe('mongoId', function () {
it('should not throw for valid mongo ids', function () {
expect(() =>
assert.mongoId('507f1f77bcf86cd799439011', 'should be a mongo id')
).to.not.throw()
})
it('should throw for invalid mongo ids', function () {
try {
assert.mongoId('invalid-id', 'should be a mongo id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a mongo id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: 'invalid-id' })
}
})
it('should throw for numeric mongo ids', function () {
try {
assert.mongoId('12345', 'should be a mongo id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a mongo id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: '12345' })
}
})
it('should throw for mongo ids that are too short', function () {
try {
assert.mongoId('507f1f77bcf86cd79943901', 'should be a mongo id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a mongo id')
expect(OError.getFullInfo(error)).to.deep.equal({
arg: '507f1f77bcf86cd79943901',
})
}
})
it('should throw for mongo ids that are too long', function () {
try {
assert.mongoId('507f1f77bcf86cd7994390111', 'should be a mongo id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a mongo id')
expect(OError.getFullInfo(error)).to.deep.equal({
arg: '507f1f77bcf86cd7994390111',
})
}
})
})
describe('postgresId', function () {
it('should not throw for valid postgres ids', function () {
expect(() =>
assert.postgresId('123456789', 'should be a postgres id')
).to.not.throw()
expect(() =>
assert.postgresId('1', 'should be a postgres id')
).to.not.throw()
})
it('should throw for invalid postgres ids', function () {
try {
assert.postgresId('invalid-id', 'should be a postgres id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a postgres id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: 'invalid-id' })
}
})
it('should throw for postgres ids starting with 0', function () {
try {
assert.postgresId('0123456', 'should be a postgres id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a postgres id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: '0123456' })
}
})
it('should throw for postgres ids that are too long', function () {
try {
assert.postgresId('12345678901', 'should be a postgres id')
expect.fail()
} catch (error) {
expect(error).to.be.instanceOf(TypeError)
expect(error.message).to.equal('should be a postgres id')
expect(OError.getFullInfo(error)).to.deep.equal({ arg: '12345678901' })
}
})
})
describe('regex constants', function () {
it('MONGO_ID_REGEXP should match valid mongo ids', function () {
expect('507f1f77bcf86cd799439011').to.match(assert.MONGO_ID_REGEXP)
expect('abcdef0123456789abcdef01').to.match(assert.MONGO_ID_REGEXP)
})
it('MONGO_ID_REGEXP should not match invalid mongo ids', function () {
expect('invalid-id').to.not.match(assert.MONGO_ID_REGEXP)
expect('507f1f77bcf86cd79943901').to.not.match(assert.MONGO_ID_REGEXP) // too short
expect('507f1f77bcf86cd7994390111').to.not.match(assert.MONGO_ID_REGEXP) // too long
expect('507F1F77BCF86CD799439011').to.not.match(assert.MONGO_ID_REGEXP) // uppercase
})
it('POSTGRES_ID_REGEXP should match valid postgres ids', function () {
expect('123456789').to.match(assert.POSTGRES_ID_REGEXP)
expect('1').to.match(assert.POSTGRES_ID_REGEXP)
})
it('POSTGRES_ID_REGEXP should not match invalid postgres ids', function () {
expect('invalid-id').to.not.match(assert.POSTGRES_ID_REGEXP)
expect('0123456').to.not.match(assert.POSTGRES_ID_REGEXP) // starts with 0
expect('12345678901').to.not.match(assert.POSTGRES_ID_REGEXP) // too long (> 10 digits)
})
})
})