1
0
mirror of https://github.com/misskey-dev/misskey.git synced 2026-05-03 18:26:13 +02:00

fix(backend): handle array or string in alsoKnownAs (#17275)

* fix: handle array or string in alsoKnownAs, closes #17274

* style: use more idiomatic toArray() for UserEntityService handling of alsoKnownAs

* fix: handle array-valued or unwrapped alsoKnownAs in ApPersonService

* doc: note about bugfix for alsoKnownAs
This commit is contained in:
Evan Prodromou
2026-04-04 11:43:37 -04:00
committed by GitHub
parent e601fcb729
commit 8169c57bd1
5 changed files with 144 additions and 88 deletions

View File

@@ -224,6 +224,51 @@ describe('ActivityPub', () => {
});
});
describe('alsoKnownAs field', () => {
test('Handle alsoKnownAs as an array', async () => {
const actor = {
...createRandomActor(),
alsoKnownAs: ['https://example.com/users/alice', 'https://example.com/users/alice2'],
};
resolver.register(actor.id, actor);
const user = await personService.createPerson(actor.id, resolver);
assert.deepStrictEqual(user.alsoKnownAs, actor.alsoKnownAs);
});
test('Handle alsoKnownAs as a string', async () => {
const actor = {
...createRandomActor(),
alsoKnownAs: 'https://example.com/users/alice',
};
resolver.register(actor.id, actor);
const user = await personService.createPerson(actor.id, resolver);
assert.deepStrictEqual(user.alsoKnownAs, [actor.alsoKnownAs]);
});
test('Update person with alsoKnownAs as a string', async () => {
const actor = createRandomActor();
resolver.register(actor.id, actor);
const user = await personService.createPerson(actor.id, resolver);
const updatedActor = {
...actor,
alsoKnownAs: 'https://example.com/users/alice',
};
resolver.register(actor.id, updatedActor);
await personService.updatePerson(actor.id, resolver, updatedActor);
const updatedUser = await personService.fetchPerson(actor.id);
assert.deepStrictEqual(updatedUser?.alsoKnownAs, [updatedActor.alsoKnownAs]);
});
});
describe('Collection visibility', () => {
test('Public following/followers', async () => {
const actor = createRandomActor();