-
Notifications
You must be signed in to change notification settings - Fork 12
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: David Dal Busco <david.dalbusco@outlook.com>
- Loading branch information
1 parent
7ed3b07
commit b415cbb
Showing
1 changed file
with
129 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,129 @@ | ||
import type { _SERVICE as OrbiterActor0_0_7 } from '$declarations/deprecated/orbiter-0-0-7.did'; | ||
import { idlFactory as idlFactorOrbiter0_0_7 } from '$declarations/deprecated/orbiter-0-0-7.factory.did'; | ||
import type { _SERVICE as OrbiterActor } from '$declarations/orbiter/orbiter.did'; | ||
import { idlFactory as idlFactorOrbiter } from '$declarations/orbiter/orbiter.factory.did'; | ||
import { Ed25519KeyIdentity } from '@dfinity/identity'; | ||
import { Principal } from '@dfinity/principal'; | ||
import { fromNullable } from '@dfinity/utils'; | ||
import { PocketIc, type Actor } from '@hadronous/pic'; | ||
import { afterEach, beforeEach, describe, expect, inject } from 'vitest'; | ||
import { satelliteIdMock } from './mocks/orbiter.mocks'; | ||
import { tick } from './utils/pic-tests.utils'; | ||
import { ORBITER_WASM_PATH, controllersInitArgs, downloadOrbiter } from './utils/setup-tests.utils'; | ||
|
||
describe('Orbiter upgrade- Configuration', () => { | ||
let pic: PocketIc; | ||
let actor: Actor<OrbiterActor0_0_7>; | ||
let canisterId: Principal; | ||
|
||
const controller = Ed25519KeyIdentity.generate(); | ||
|
||
afterEach(async () => { | ||
await pic?.tearDown(); | ||
}); | ||
|
||
const upgrade = async () => { | ||
await tick(pic); | ||
|
||
await pic.upgradeCanister({ | ||
canisterId, | ||
wasm: ORBITER_WASM_PATH, | ||
sender: controller.getPrincipal() | ||
}); | ||
}; | ||
|
||
describe('v0.0.7 -> v0.0.8', async () => { | ||
beforeEach(async () => { | ||
pic = await PocketIc.create(inject('PIC_URL')); | ||
|
||
const destination = await downloadOrbiter('0.0.7'); | ||
|
||
const { actor: c, canisterId: cId } = await pic.setupCanister<OrbiterActor0_0_7>({ | ||
idlFactory: idlFactorOrbiter0_0_7, | ||
wasm: destination, | ||
arg: controllersInitArgs(controller), | ||
sender: controller.getPrincipal() | ||
}); | ||
|
||
actor = c; | ||
canisterId = cId; | ||
actor.setIdentity(controller); | ||
}); | ||
|
||
it('should migrate no entry if the configuration was not set', async () => { | ||
await upgrade(); | ||
|
||
const newActor = pic.createActor<OrbiterActor>(idlFactorOrbiter, canisterId); | ||
newActor.setIdentity(controller); | ||
|
||
const { list_satellite_configs } = newActor; | ||
|
||
const configs = await list_satellite_configs(); | ||
expect(configs.length).toBe(0); | ||
}); | ||
|
||
it('should migrate configuration disabled to none', async () => { | ||
const { set_satellite_configs } = actor; | ||
|
||
await expect( | ||
set_satellite_configs([ | ||
[ | ||
satelliteIdMock, | ||
{ | ||
version: [], | ||
enabled: false | ||
} | ||
] | ||
]) | ||
).resolves.not.toThrowError(); | ||
|
||
await upgrade(); | ||
|
||
const newActor = pic.createActor<OrbiterActor>(idlFactorOrbiter, canisterId); | ||
newActor.setIdentity(controller); | ||
|
||
const { list_satellite_configs } = newActor; | ||
|
||
const configs = await list_satellite_configs(); | ||
expect(configs.length).toBe(1); | ||
|
||
expect(configs[0][0].toText()).toEqual(satelliteIdMock.toText()); | ||
expect(fromNullable(configs[0][1].version)).toBe(1n); | ||
expect(fromNullable(configs[0][1].features)).toBeUndefined(); | ||
}); | ||
|
||
it('should migrate configuration enabled to the new features', async () => { | ||
const { set_satellite_configs } = actor; | ||
|
||
await expect( | ||
set_satellite_configs([ | ||
[ | ||
satelliteIdMock, | ||
{ | ||
version: [], | ||
enabled: true | ||
} | ||
] | ||
]) | ||
).resolves.not.toThrowError(); | ||
|
||
await upgrade(); | ||
|
||
const newActor = pic.createActor<OrbiterActor>(idlFactorOrbiter, canisterId); | ||
newActor.setIdentity(controller); | ||
|
||
const { list_satellite_configs } = newActor; | ||
|
||
const configs = await list_satellite_configs(); | ||
expect(configs.length).toBe(1); | ||
|
||
expect(configs[0][0].toText()).toEqual(satelliteIdMock.toText()); | ||
expect(fromNullable(configs[0][1].version)).toBe(1n); | ||
expect(fromNullable(configs[0][1].features)).toEqual({ | ||
page_views: true, | ||
performance_metrics: true, | ||
track_events: true | ||
}); | ||
}); | ||
}); | ||
}); |