Fix runtime error during SQL migration

This commit is contained in:
Fedor Indutny 2021-10-27 10:15:03 -07:00 committed by GitHub
parent 30078ce3aa
commit 246583d274
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 34 additions and 9 deletions

View File

@ -5,7 +5,6 @@ import type { Database } from 'better-sqlite3';
import { omit } from 'lodash';
import type { LoggerType } from '../../types/Logging';
import { UUID } from '../../types/UUID';
import type { UUIDStringType } from '../../types/UUID';
import { isNotNil } from '../../util/isNotNil';
import { assert } from '../../util/assert';
@ -265,11 +264,11 @@ export default function updateToSchemaVersion43(
}
changedDetails = true;
let newValue: UUIDStringType | null = getConversationUuid.get({
const newValue: UUIDStringType | null = getConversationUuid.get({
conversationId: oldValue,
});
if (key === 'inviter') {
newValue = newValue ?? UUID.cast(oldValue);
if (key === 'inviter' && !newValue) {
continue;
}
if (!newValue) {
logger.warn(
@ -302,12 +301,11 @@ export default function updateToSchemaVersion43(
}
if (sourceUuid) {
const newValue: UUIDStringType =
getConversationUuid.get({
conversationId: sourceUuid,
}) ?? UUID.cast(sourceUuid);
const newValue: UUIDStringType | null = getConversationUuid.get({
conversationId: sourceUuid,
});
if (newValue !== sourceUuid) {
if (newValue) {
result = {
...result,
sourceUuid: newValue,

View File

@ -769,5 +769,32 @@ describe('SQL migrations test', () => {
sourceUuid: UUID_A,
});
});
it('should not fail on invalid UUIDs', () => {
updateToVersion(42);
db.exec(
`
INSERT INTO messages
(id, json)
VALUES
('m', '${JSON.stringify({
id: 'm',
sourceUuid: 'ffffffff-ffff-ffff-ffff-ffffffffffff',
})}');
`
);
updateToVersion(43);
const { json: messageMJSON } = db
.prepare('SELECT json FROM messages WHERE id = "m"')
.get();
assert.deepStrictEqual(JSON.parse(messageMJSON), {
id: 'm',
sourceUuid: 'ffffffff-ffff-ffff-ffff-ffffffffffff',
});
});
});
});