Skip to content

Commit

Permalink
Merge pull request #345 from nrkno/chore/filter-mappings
Browse files Browse the repository at this point in the history
Filter mappings such that an integration only sees its own mappings
  • Loading branch information
mint-dewit authored Aug 30, 2024
2 parents 6cecf90 + 17e3b75 commit 7d1db9c
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 9 deletions.
20 changes: 13 additions & 7 deletions packages/timeline-state-resolver/src/__tests__/conductor.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -58,10 +58,16 @@ describe('Conductor', () => {
deviceId: 'device1',
options: {},
}
const myLayerMapping: Mappings = {
const device0Mappings: Mappings = {
myLayer0: myLayerMapping0,
}
const device1Mappings: Mappings = {
myLayer1: myLayerMapping1,
}
const myLayerMapping: Mappings = {
...device0Mappings,
...device1Mappings,
}

const conductor = new Conductor({
multiThreadedResolver: false,
Expand Down Expand Up @@ -139,22 +145,22 @@ describe('Conductor', () => {
},
time: 10005,
}),
myLayerMapping // TODO - is this correct?
device0Mappings
)
expect(device0.handleState).toHaveBeenNthCalledWith(
2,
expect.objectContaining({
time: 11000,
}),
myLayerMapping // TODO - is this correct?
device0Mappings
)
expect(device0.handleState).toHaveBeenNthCalledWith(
3,
expect.objectContaining({
layers: {},
time: 12000,
}),
myLayerMapping // TODO - is this correct?
device0Mappings
)

// Ensure device1 has been fed sensible states
Expand All @@ -165,7 +171,7 @@ describe('Conductor', () => {
expect.objectContaining({
layers: {},
}),
myLayerMapping // TODO - is this correct?
device1Mappings
)
expect(device1.handleState).toHaveBeenNthCalledWith(
2,
Expand All @@ -180,14 +186,14 @@ describe('Conductor', () => {
}),
},
}),
myLayerMapping // TODO - is this correct?
device1Mappings
)
expect(device1.handleState).toHaveBeenNthCalledWith(
3,
expect.objectContaining({
layers: {},
}),
myLayerMapping // TODO - is this correct?
device1Mappings
)

// Remove the device
Expand Down
7 changes: 6 additions & 1 deletion packages/timeline-state-resolver/src/conductor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1087,8 +1087,13 @@ export class Conductor extends EventEmitter<ConductorEvents> {
deviceId: string,
time: number,
state: Timeline.TimelineState<TSRTimelineContent>,
mappings: Mappings
unfilteredMappings: Mappings
) {
// only take mappings that are for this deviceId
const mappings = Object.fromEntries(
Object.entries<Mapping<unknown>>(unfilteredMappings).filter(([_, mapping]) => mapping.deviceId === deviceId)
)

if (!this._deviceStates[deviceId]) this._deviceStates[deviceId] = []

// find all references to the datastore that are in this state
Expand Down
2 changes: 1 addition & 1 deletion packages/timeline-state-resolver/src/service/devices.ts
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,6 @@ export const DevicesDict: Record<ImplementedServiceDeviceTypes, DeviceEntry> = {
deviceClass: QuantelDevice,
canConnect: true,
deviceName: (deviceId: string) => 'Quantel' + deviceId,
executionMode: () => 'salvo',
executionMode: () => 'sequential',
},
}

0 comments on commit 7d1db9c

Please sign in to comment.