sportident.js 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -27
- package/SiCard/BaseSiCard.d.ts +35 -0
- package/SiCard/BaseSiCard.d.ts.map +1 -0
- package/SiCard/BaseSiCard.js +99 -0
- package/SiCard/BaseSiCard.js.map +1 -0
- package/SiCard/BaseSiCard.test.d.ts +2 -0
- package/SiCard/BaseSiCard.test.d.ts.map +1 -0
- package/SiCard/BaseSiCard.test.js +190 -0
- package/SiCard/BaseSiCard.test.js.map +1 -0
- package/SiCard/IRaceResultData.d.ts +17 -0
- package/SiCard/IRaceResultData.d.ts.map +1 -0
- package/SiCard/IRaceResultData.js +3 -0
- package/SiCard/IRaceResultData.js.map +1 -0
- package/SiCard/ISiCard.d.ts +24 -0
- package/SiCard/ISiCard.d.ts.map +1 -0
- package/SiCard/ISiCard.js +3 -0
- package/SiCard/ISiCard.js.map +1 -0
- package/SiCard/ISiCardExamples.d.ts +9 -0
- package/SiCard/ISiCardExamples.d.ts.map +1 -0
- package/SiCard/ISiCardExamples.js +3 -0
- package/SiCard/ISiCardExamples.js.map +1 -0
- package/{src/SiCard/index.ts → SiCard/index.d.ts} +1 -0
- package/SiCard/index.d.ts.map +1 -0
- package/SiCard/index.js +21 -0
- package/SiCard/index.js.map +1 -0
- package/SiCard/raceResultTools.d.ts +25 -0
- package/SiCard/raceResultTools.d.ts.map +1 -0
- package/SiCard/raceResultTools.js +155 -0
- package/SiCard/raceResultTools.js.map +1 -0
- package/SiCard/raceResultTools.test.d.ts +2 -0
- package/SiCard/raceResultTools.test.d.ts.map +1 -0
- package/SiCard/raceResultTools.test.js +255 -0
- package/SiCard/raceResultTools.test.js.map +1 -0
- package/SiCard/types/FCard.d.ts +7 -0
- package/SiCard/types/FCard.d.ts.map +1 -0
- package/SiCard/types/FCard.js +49 -0
- package/SiCard/types/FCard.js.map +1 -0
- package/SiCard/types/FCard.test.d.ts +2 -0
- package/SiCard/types/FCard.test.d.ts.map +1 -0
- package/SiCard/types/FCard.test.js +18 -0
- package/SiCard/types/FCard.test.js.map +1 -0
- package/SiCard/types/ModernSiCard.d.ts +48 -0
- package/SiCard/types/ModernSiCard.d.ts.map +1 -0
- package/SiCard/types/ModernSiCard.js +238 -0
- package/SiCard/types/ModernSiCard.js.map +1 -0
- package/SiCard/types/ModernSiCard.test.d.ts +2 -0
- package/SiCard/types/ModernSiCard.test.d.ts.map +1 -0
- package/SiCard/types/ModernSiCard.test.js +214 -0
- package/SiCard/types/ModernSiCard.test.js.map +1 -0
- package/SiCard/types/PCard.d.ts +7 -0
- package/SiCard/types/PCard.d.ts.map +1 -0
- package/SiCard/types/PCard.js +49 -0
- package/SiCard/types/PCard.js.map +1 -0
- package/SiCard/types/PCard.test.d.ts +2 -0
- package/SiCard/types/PCard.test.d.ts.map +1 -0
- package/SiCard/types/PCard.test.js +18 -0
- package/SiCard/types/PCard.test.js.map +1 -0
- package/SiCard/types/SIAC.d.ts +6 -0
- package/SiCard/types/SIAC.d.ts.map +1 -0
- package/SiCard/types/SIAC.js +22 -0
- package/SiCard/types/SIAC.js.map +1 -0
- package/SiCard/types/SIAC.test.d.ts +2 -0
- package/SiCard/types/SIAC.test.d.ts.map +1 -0
- package/SiCard/types/SIAC.test.js +113 -0
- package/SiCard/types/SIAC.test.js.map +1 -0
- package/SiCard/types/SiCard10.d.ts +6 -0
- package/SiCard/types/SiCard10.d.ts.map +1 -0
- package/SiCard/types/SiCard10.js +20 -0
- package/SiCard/types/SiCard10.js.map +1 -0
- package/SiCard/types/SiCard10.test.d.ts +2 -0
- package/SiCard/types/SiCard10.test.d.ts.map +1 -0
- package/SiCard/types/SiCard10.test.js +114 -0
- package/SiCard/types/SiCard10.test.js.map +1 -0
- package/SiCard/types/SiCard11.d.ts +6 -0
- package/SiCard/types/SiCard11.d.ts.map +1 -0
- package/SiCard/types/SiCard11.js +22 -0
- package/SiCard/types/SiCard11.js.map +1 -0
- package/SiCard/types/SiCard11.test.d.ts +2 -0
- package/SiCard/types/SiCard11.test.d.ts.map +1 -0
- package/SiCard/types/SiCard11.test.js +113 -0
- package/SiCard/types/SiCard11.test.js.map +1 -0
- package/SiCard/types/SiCard5.d.ts +31 -0
- package/SiCard/types/SiCard5.d.ts.map +1 -0
- package/SiCard/types/SiCard5.js +128 -0
- package/SiCard/types/SiCard5.js.map +1 -0
- package/SiCard/types/SiCard5.test.d.ts +2 -0
- package/SiCard/types/SiCard5.test.d.ts.map +1 -0
- package/SiCard/types/SiCard5.test.js +170 -0
- package/SiCard/types/SiCard5.test.js.map +1 -0
- package/SiCard/types/SiCard6.d.ts +49 -0
- package/SiCard/types/SiCard6.d.ts.map +1 -0
- package/SiCard/types/SiCard6.js +203 -0
- package/SiCard/types/SiCard6.js.map +1 -0
- package/SiCard/types/SiCard6.test.d.ts +2 -0
- package/SiCard/types/SiCard6.test.d.ts.map +1 -0
- package/SiCard/types/SiCard6.test.js +202 -0
- package/SiCard/types/SiCard6.test.js.map +1 -0
- package/SiCard/types/SiCard8.d.ts +20 -0
- package/SiCard/types/SiCard8.d.ts.map +1 -0
- package/SiCard/types/SiCard8.js +140 -0
- package/SiCard/types/SiCard8.js.map +1 -0
- package/SiCard/types/SiCard8.test.d.ts +2 -0
- package/SiCard/types/SiCard8.test.d.ts.map +1 -0
- package/SiCard/types/SiCard8.test.js +159 -0
- package/SiCard/types/SiCard8.test.js.map +1 -0
- package/SiCard/types/SiCard9.d.ts +20 -0
- package/SiCard/types/SiCard9.d.ts.map +1 -0
- package/SiCard/types/SiCard9.js +139 -0
- package/SiCard/types/SiCard9.js.map +1 -0
- package/SiCard/types/SiCard9.test.d.ts +2 -0
- package/SiCard/types/SiCard9.test.d.ts.map +1 -0
- package/SiCard/types/SiCard9.test.js +155 -0
- package/SiCard/types/SiCard9.test.js.map +1 -0
- package/SiCard/types/TCard.d.ts +7 -0
- package/SiCard/types/TCard.d.ts.map +1 -0
- package/SiCard/types/TCard.js +49 -0
- package/SiCard/types/TCard.js.map +1 -0
- package/SiCard/types/TCard.test.d.ts +2 -0
- package/SiCard/types/TCard.test.d.ts.map +1 -0
- package/SiCard/types/TCard.test.js +18 -0
- package/SiCard/types/TCard.test.js.map +1 -0
- package/{src/SiCard/types/index.ts → SiCard/types/index.d.ts} +1 -0
- package/SiCard/types/index.d.ts.map +1 -0
- package/SiCard/types/index.js +34 -0
- package/SiCard/types/index.js.map +1 -0
- package/SiCard/types/index.test.d.ts +2 -0
- package/SiCard/types/index.test.d.ts.map +1 -0
- package/SiCard/types/index.test.js +65 -0
- package/SiCard/types/index.test.js.map +1 -0
- package/SiCard/types/modernSiCardExamples.d.ts +254 -0
- package/SiCard/types/modernSiCardExamples.d.ts.map +1 -0
- package/SiCard/types/modernSiCardExamples.js +389 -0
- package/SiCard/types/modernSiCardExamples.js.map +1 -0
- package/SiCard/types/siCard5Examples.d.ts +50 -0
- package/SiCard/types/siCard5Examples.d.ts.map +1 -0
- package/SiCard/types/siCard5Examples.js +109 -0
- package/SiCard/types/siCard5Examples.js.map +1 -0
- package/SiCard/types/siCard6Examples.d.ts +190 -0
- package/SiCard/types/siCard6Examples.d.ts.map +1 -0
- package/SiCard/types/siCard6Examples.js +289 -0
- package/SiCard/types/siCard6Examples.js.map +1 -0
- package/SiCard/types/siCard8Examples.d.ts +98 -0
- package/SiCard/types/siCard8Examples.d.ts.map +1 -0
- package/SiCard/types/siCard8Examples.js +182 -0
- package/SiCard/types/siCard8Examples.js.map +1 -0
- package/SiCard/types/siCard9Examples.d.ts +98 -0
- package/SiCard/types/siCard9Examples.d.ts.map +1 -0
- package/SiCard/types/siCard9Examples.js +173 -0
- package/SiCard/types/siCard9Examples.js.map +1 -0
- package/SiDevice/INavigatorWebSerial.d.ts +62 -0
- package/SiDevice/INavigatorWebSerial.d.ts.map +1 -0
- package/SiDevice/INavigatorWebSerial.js +3 -0
- package/SiDevice/INavigatorWebSerial.js.map +1 -0
- package/SiDevice/INavigatorWebUsb.d.ts +55 -0
- package/SiDevice/INavigatorWebUsb.d.ts.map +1 -0
- package/SiDevice/INavigatorWebUsb.js +3 -0
- package/SiDevice/INavigatorWebUsb.js.map +1 -0
- package/SiDevice/ISiDevice.d.ts +42 -0
- package/SiDevice/ISiDevice.d.ts.map +1 -0
- package/SiDevice/ISiDevice.js +65 -0
- package/SiDevice/ISiDevice.js.map +1 -0
- package/SiDevice/ISiDeviceDriver.d.ts +29 -0
- package/SiDevice/ISiDeviceDriver.d.ts.map +1 -0
- package/SiDevice/ISiDeviceDriver.js +52 -0
- package/SiDevice/ISiDeviceDriver.js.map +1 -0
- package/SiDevice/SiDevice.d.ts +21 -0
- package/SiDevice/SiDevice.d.ts.map +1 -0
- package/SiDevice/SiDevice.js +156 -0
- package/SiDevice/SiDevice.js.map +1 -0
- package/SiDevice/SiDevice.test.d.ts +2 -0
- package/SiDevice/SiDevice.test.d.ts.map +1 -0
- package/SiDevice/SiDevice.test.js +366 -0
- package/SiDevice/SiDevice.test.js.map +1 -0
- package/SiDevice/WebSerialSiDeviceDriver.d.ts +31 -0
- package/SiDevice/WebSerialSiDeviceDriver.d.ts.map +1 -0
- package/SiDevice/WebSerialSiDeviceDriver.js +175 -0
- package/SiDevice/WebSerialSiDeviceDriver.js.map +1 -0
- package/SiDevice/WebUsbSiDeviceDriver.d.ts +39 -0
- package/SiDevice/WebUsbSiDeviceDriver.d.ts.map +1 -0
- package/SiDevice/WebUsbSiDeviceDriver.js +359 -0
- package/SiDevice/WebUsbSiDeviceDriver.js.map +1 -0
- package/{src/SiDevice/index.ts → SiDevice/index.d.ts} +1 -0
- package/SiDevice/index.d.ts.map +1 -0
- package/SiDevice/index.js +6 -0
- package/SiDevice/index.js.map +1 -0
- package/{src/SiDevice/testUtils/index.ts → SiDevice/testUtils/index.d.ts} +1 -0
- package/SiDevice/testUtils/index.d.ts.map +1 -0
- package/SiDevice/testUtils/index.js +8 -0
- package/SiDevice/testUtils/index.js.map +1 -0
- package/SiDevice/testUtils/testISiDeviceDriver.d.ts +8 -0
- package/SiDevice/testUtils/testISiDeviceDriver.d.ts.map +1 -0
- package/SiDevice/testUtils/testISiDeviceDriver.js +94 -0
- package/SiDevice/testUtils/testISiDeviceDriver.js.map +1 -0
- package/SiDevice/testUtils/testISiDeviceDriverWithAutodetection.d.ts +8 -0
- package/SiDevice/testUtils/testISiDeviceDriverWithAutodetection.d.ts.map +1 -0
- package/SiDevice/testUtils/testISiDeviceDriverWithAutodetection.js +95 -0
- package/SiDevice/testUtils/testISiDeviceDriverWithAutodetection.js.map +1 -0
- package/SiStation/BaseSiStation.d.ts +61 -0
- package/SiStation/BaseSiStation.d.ts.map +1 -0
- package/SiStation/BaseSiStation.js +217 -0
- package/SiStation/BaseSiStation.js.map +1 -0
- package/SiStation/BaseSiStation.test.d.ts +2 -0
- package/SiStation/BaseSiStation.test.d.ts.map +1 -0
- package/SiStation/BaseSiStation.test.js +242 -0
- package/SiStation/BaseSiStation.test.js.map +1 -0
- package/SiStation/CoupledSiStation.d.ts +14 -0
- package/SiStation/CoupledSiStation.d.ts.map +1 -0
- package/SiStation/CoupledSiStation.js +156 -0
- package/SiStation/CoupledSiStation.js.map +1 -0
- package/SiStation/CoupledSiStation.test.d.ts +2 -0
- package/SiStation/CoupledSiStation.test.d.ts.map +1 -0
- package/SiStation/CoupledSiStation.test.js +72 -0
- package/SiStation/CoupledSiStation.test.js.map +1 -0
- package/SiStation/ISiMainStation.d.ts +25 -0
- package/SiStation/ISiMainStation.d.ts.map +1 -0
- package/SiStation/ISiMainStation.js +62 -0
- package/SiStation/ISiMainStation.js.map +1 -0
- package/SiStation/ISiSendTask.d.ts +8 -0
- package/SiStation/ISiSendTask.d.ts.map +1 -0
- package/SiStation/ISiSendTask.js +14 -0
- package/SiStation/ISiSendTask.js.map +1 -0
- package/SiStation/ISiStation.d.ts +62 -0
- package/SiStation/ISiStation.d.ts.map +1 -0
- package/SiStation/ISiStation.js +76 -0
- package/SiStation/ISiStation.js.map +1 -0
- package/SiStation/ISiTargetMultiplexer.d.ts +47 -0
- package/SiStation/ISiTargetMultiplexer.d.ts.map +1 -0
- package/SiStation/ISiTargetMultiplexer.js +71 -0
- package/SiStation/ISiTargetMultiplexer.js.map +1 -0
- package/SiStation/SiMainStation.d.ts +24 -0
- package/SiStation/SiMainStation.d.ts.map +1 -0
- package/SiStation/SiMainStation.js +142 -0
- package/SiStation/SiMainStation.js.map +1 -0
- package/SiStation/SiMainStation.test.d.ts +2 -0
- package/SiStation/SiMainStation.test.d.ts.map +1 -0
- package/SiStation/SiMainStation.test.js +235 -0
- package/SiStation/SiMainStation.test.js.map +1 -0
- package/SiStation/SiSendTask.d.ts +17 -0
- package/SiStation/SiSendTask.d.ts.map +1 -0
- package/SiStation/SiSendTask.js +81 -0
- package/SiStation/SiSendTask.js.map +1 -0
- package/SiStation/SiTargetMultiplexer.d.ts +34 -0
- package/SiStation/SiTargetMultiplexer.d.ts.map +1 -0
- package/SiStation/SiTargetMultiplexer.js +254 -0
- package/SiStation/SiTargetMultiplexer.js.map +1 -0
- package/SiStation/SiTargetMultiplexer.targeting.test.d.ts +2 -0
- package/SiStation/SiTargetMultiplexer.targeting.test.d.ts.map +1 -0
- package/SiStation/SiTargetMultiplexer.targeting.test.js +138 -0
- package/SiStation/SiTargetMultiplexer.targeting.test.js.map +1 -0
- package/SiStation/SiTargetMultiplexer.test.d.ts +2 -0
- package/SiStation/SiTargetMultiplexer.test.d.ts.map +1 -0
- package/SiStation/SiTargetMultiplexer.test.js +588 -0
- package/SiStation/SiTargetMultiplexer.test.js.map +1 -0
- package/{src/SiStation/index.ts → SiStation/index.d.ts} +1 -0
- package/SiStation/index.d.ts.map +1 -0
- package/SiStation/index.js +14 -0
- package/SiStation/index.js.map +1 -0
- package/SiStation/siStationExamples.d.ts +76 -0
- package/SiStation/siStationExamples.d.ts.map +1 -0
- package/SiStation/siStationExamples.js +132 -0
- package/SiStation/siStationExamples.js.map +1 -0
- package/constants.d.ts +76 -0
- package/constants.d.ts.map +1 -0
- package/constants.js +88 -0
- package/constants.js.map +1 -0
- package/constants.test.d.ts +2 -0
- package/constants.test.d.ts.map +1 -0
- package/constants.test.js +52 -0
- package/constants.test.js.map +1 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.d.ts +8 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.d.ts.map +1 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.js +10 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.js.map +1 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.test.d.ts +2 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.test.d.ts.map +1 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.test.js +45 -0
- package/fakes/FakeSiCard/BaseFakeSiCard.test.js.map +1 -0
- package/fakes/FakeSiCard/IFakeSiCard.d.ts +6 -0
- package/fakes/FakeSiCard/IFakeSiCard.d.ts.map +1 -0
- package/fakes/FakeSiCard/IFakeSiCard.js +3 -0
- package/fakes/FakeSiCard/IFakeSiCard.js.map +1 -0
- package/{src/fakes/FakeSiCard/index.ts → fakes/FakeSiCard/index.d.ts} +1 -0
- package/fakes/FakeSiCard/index.d.ts.map +1 -0
- package/fakes/FakeSiCard/index.js +21 -0
- package/fakes/FakeSiCard/index.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.d.ts +15 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.js +73 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.test.d.ts +2 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.test.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.test.js +88 -0
- package/fakes/FakeSiCard/types/FakeModernSiCard.test.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSIAC.d.ts +13 -0
- package/fakes/FakeSiCard/types/FakeSIAC.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSIAC.js +17 -0
- package/fakes/FakeSiCard/types/FakeSIAC.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard10.d.ts +13 -0
- package/fakes/FakeSiCard/types/FakeSiCard10.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard10.js +17 -0
- package/fakes/FakeSiCard/types/FakeSiCard10.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard11.d.ts +13 -0
- package/fakes/FakeSiCard/types/FakeSiCard11.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard11.js +17 -0
- package/fakes/FakeSiCard/types/FakeSiCard11.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.d.ts +15 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.js +70 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.test.d.ts +2 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.test.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.test.js +71 -0
- package/fakes/FakeSiCard/types/FakeSiCard5.test.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.d.ts +15 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.js +73 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.test.d.ts +2 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.test.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.test.js +88 -0
- package/fakes/FakeSiCard/types/FakeSiCard6.test.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard8.d.ts +12 -0
- package/fakes/FakeSiCard/types/FakeSiCard8.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard8.js +16 -0
- package/fakes/FakeSiCard/types/FakeSiCard8.js.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard9.d.ts +12 -0
- package/fakes/FakeSiCard/types/FakeSiCard9.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/FakeSiCard9.js +16 -0
- package/fakes/FakeSiCard/types/FakeSiCard9.js.map +1 -0
- package/{src/fakes/FakeSiCard/types/index.ts → fakes/FakeSiCard/types/index.d.ts} +1 -0
- package/fakes/FakeSiCard/types/index.d.ts.map +1 -0
- package/fakes/FakeSiCard/types/index.js +18 -0
- package/fakes/FakeSiCard/types/index.js.map +1 -0
- package/fakes/FakeSiDeviceDriver.d.ts +42 -0
- package/fakes/FakeSiDeviceDriver.d.ts.map +1 -0
- package/fakes/FakeSiDeviceDriver.js +163 -0
- package/fakes/FakeSiDeviceDriver.js.map +1 -0
- package/fakes/FakeSiMainStation.d.ts +22 -0
- package/fakes/FakeSiMainStation.d.ts.map +1 -0
- package/fakes/FakeSiMainStation.js +150 -0
- package/fakes/FakeSiMainStation.js.map +1 -0
- package/fakes/FakeSiMainStation.test.d.ts +2 -0
- package/fakes/FakeSiMainStation.test.d.ts.map +1 -0
- package/fakes/FakeSiMainStation.test.js +150 -0
- package/fakes/FakeSiMainStation.test.js.map +1 -0
- package/fakes/IFakeSiMainStation.d.ts +14 -0
- package/fakes/IFakeSiMainStation.d.ts.map +1 -0
- package/fakes/IFakeSiMainStation.js +46 -0
- package/fakes/IFakeSiMainStation.js.map +1 -0
- package/{src/fakes/index.ts → fakes/index.d.ts} +1 -0
- package/fakes/index.d.ts.map +1 -0
- package/fakes/index.js +21 -0
- package/fakes/index.js.map +1 -0
- package/index.d.ts +72 -0
- package/index.d.ts.map +1 -0
- package/index.js +49 -0
- package/index.js.map +1 -0
- package/package.json +2 -4
- package/siProtocol.d.ts +58 -0
- package/siProtocol.d.ts.map +1 -0
- package/siProtocol.js +413 -0
- package/siProtocol.js.map +1 -0
- package/siProtocol.test.d.ts +2 -0
- package/siProtocol.test.d.ts.map +1 -0
- package/siProtocol.test.js +524 -0
- package/siProtocol.test.js.map +1 -0
- package/storage/SiArray.d.ts +14 -0
- package/storage/SiArray.d.ts.map +1 -0
- package/storage/SiArray.js +58 -0
- package/storage/SiArray.js.map +1 -0
- package/storage/SiArray.test.d.ts +2 -0
- package/storage/SiArray.test.d.ts.map +1 -0
- package/storage/SiArray.test.js +100 -0
- package/storage/SiArray.test.js.map +1 -0
- package/storage/SiBool.d.ts +13 -0
- package/storage/SiBool.d.ts.map +1 -0
- package/storage/SiBool.js +47 -0
- package/storage/SiBool.js.map +1 -0
- package/storage/SiBool.test.d.ts +2 -0
- package/storage/SiBool.test.d.ts.map +1 -0
- package/storage/SiBool.test.js +80 -0
- package/storage/SiBool.test.js.map +1 -0
- package/storage/SiDataType.d.ts +19 -0
- package/storage/SiDataType.d.ts.map +1 -0
- package/storage/SiDataType.js +50 -0
- package/storage/SiDataType.js.map +1 -0
- package/storage/SiDataType.test.d.ts +2 -0
- package/storage/SiDataType.test.d.ts.map +1 -0
- package/storage/SiDataType.test.js +80 -0
- package/storage/SiDataType.test.js.map +1 -0
- package/storage/SiDict.d.ts +23 -0
- package/storage/SiDict.d.ts.map +1 -0
- package/storage/SiDict.js +56 -0
- package/storage/SiDict.js.map +1 -0
- package/storage/SiDict.test.d.ts +2 -0
- package/storage/SiDict.test.d.ts.map +1 -0
- package/storage/SiDict.test.js +107 -0
- package/storage/SiDict.test.js.map +1 -0
- package/storage/SiEnum.d.ts +21 -0
- package/storage/SiEnum.d.ts.map +1 -0
- package/storage/SiEnum.js +76 -0
- package/storage/SiEnum.js.map +1 -0
- package/storage/SiEnum.test.d.ts +2 -0
- package/storage/SiEnum.test.d.ts.map +1 -0
- package/storage/SiEnum.test.js +75 -0
- package/storage/SiEnum.test.js.map +1 -0
- package/storage/SiFieldValue.d.ts +10 -0
- package/storage/SiFieldValue.d.ts.map +1 -0
- package/storage/SiFieldValue.js +25 -0
- package/storage/SiFieldValue.js.map +1 -0
- package/storage/SiFieldValue.test.d.ts +2 -0
- package/storage/SiFieldValue.test.d.ts.map +1 -0
- package/storage/SiFieldValue.test.js +59 -0
- package/storage/SiFieldValue.test.js.map +1 -0
- package/storage/SiInt.d.ts +20 -0
- package/storage/SiInt.d.ts.map +1 -0
- package/storage/SiInt.js +73 -0
- package/storage/SiInt.js.map +1 -0
- package/storage/SiInt.test.d.ts +2 -0
- package/storage/SiInt.test.d.ts.map +1 -0
- package/storage/SiInt.test.js +79 -0
- package/storage/SiInt.test.js.map +1 -0
- package/storage/SiModified.d.ts +18 -0
- package/storage/SiModified.d.ts.map +1 -0
- package/storage/SiModified.js +56 -0
- package/storage/SiModified.js.map +1 -0
- package/storage/SiModified.test.d.ts +2 -0
- package/storage/SiModified.test.d.ts.map +1 -0
- package/storage/SiModified.test.js +122 -0
- package/storage/SiModified.test.js.map +1 -0
- package/storage/SiStorage.d.ts +14 -0
- package/storage/SiStorage.d.ts.map +1 -0
- package/storage/SiStorage.js +43 -0
- package/storage/SiStorage.js.map +1 -0
- package/storage/SiStorage.test.d.ts +2 -0
- package/storage/SiStorage.test.d.ts.map +1 -0
- package/storage/SiStorage.test.js +86 -0
- package/storage/SiStorage.test.js.map +1 -0
- package/{src/storage/index.ts → storage/index.d.ts} +2 -1
- package/storage/index.d.ts.map +1 -0
- package/storage/index.js +29 -0
- package/storage/index.js.map +1 -0
- package/storage/index.test.d.ts +2 -0
- package/storage/index.test.d.ts.map +1 -0
- package/storage/index.test.js +222 -0
- package/storage/index.test.js.map +1 -0
- package/storage/interfaces.d.ts +38 -0
- package/storage/interfaces.d.ts.map +1 -0
- package/storage/interfaces.js +44 -0
- package/storage/interfaces.js.map +1 -0
- package/storage/siStringEncoding.d.ts +2 -0
- package/storage/siStringEncoding.d.ts.map +1 -0
- package/storage/siStringEncoding.js +1365 -0
- package/storage/siStringEncoding.js.map +1 -0
- package/testUtils.d.ts +25 -0
- package/testUtils.d.ts.map +1 -0
- package/testUtils.js +79 -0
- package/testUtils.js.map +1 -0
- package/testUtils.test.d.ts +2 -0
- package/testUtils.test.d.ts.map +1 -0
- package/testUtils.test.js +307 -0
- package/testUtils.test.js.map +1 -0
- package/utils/NumberRange.d.ts +15 -0
- package/utils/NumberRange.d.ts.map +1 -0
- package/utils/NumberRange.js +48 -0
- package/utils/NumberRange.js.map +1 -0
- package/utils/NumberRange.test.d.ts +2 -0
- package/utils/NumberRange.test.d.ts.map +1 -0
- package/utils/NumberRange.test.js +68 -0
- package/utils/NumberRange.test.js.map +1 -0
- package/utils/NumberRangeRegistry.d.ts +9 -0
- package/utils/NumberRangeRegistry.d.ts.map +1 -0
- package/utils/NumberRangeRegistry.js +82 -0
- package/utils/NumberRangeRegistry.js.map +1 -0
- package/utils/NumberRangeRegistry.test.d.ts +2 -0
- package/utils/NumberRangeRegistry.test.d.ts.map +1 -0
- package/utils/NumberRangeRegistry.test.js +51 -0
- package/utils/NumberRangeRegistry.test.js.map +1 -0
- package/utils/bytes.d.ts +9 -0
- package/utils/bytes.d.ts.map +1 -0
- package/utils/bytes.js +74 -0
- package/utils/bytes.js.map +1 -0
- package/utils/bytes.test.d.ts +2 -0
- package/utils/bytes.test.d.ts.map +1 -0
- package/utils/bytes.test.js +159 -0
- package/utils/bytes.test.js.map +1 -0
- package/utils/errors.d.ts +10 -0
- package/utils/errors.d.ts.map +1 -0
- package/utils/errors.js +27 -0
- package/utils/errors.js.map +1 -0
- package/utils/errors.test.d.ts +2 -0
- package/utils/errors.test.d.ts.map +1 -0
- package/utils/errors.test.js +63 -0
- package/utils/errors.test.js.map +1 -0
- package/utils/events.d.ts +30 -0
- package/utils/events.d.ts.map +1 -0
- package/utils/events.js +81 -0
- package/utils/events.js.map +1 -0
- package/utils/events.test.d.ts +2 -0
- package/utils/events.test.d.ts.map +1 -0
- package/utils/events.test.js +130 -0
- package/utils/events.test.js.map +1 -0
- package/utils/general.d.ts +19 -0
- package/utils/general.d.ts.map +1 -0
- package/utils/general.js +63 -0
- package/utils/general.js.map +1 -0
- package/utils/general.test.d.ts +2 -0
- package/utils/general.test.d.ts.map +1 -0
- package/utils/general.test.js +182 -0
- package/utils/general.test.js.map +1 -0
- package/{src/utils/index.ts → utils/index.d.ts} +1 -0
- package/utils/index.d.ts.map +1 -0
- package/utils/index.js +25 -0
- package/utils/index.js.map +1 -0
- package/utils/mixins.d.ts +2 -0
- package/utils/mixins.d.ts.map +1 -0
- package/utils/mixins.js +15 -0
- package/utils/mixins.js.map +1 -0
- package/utils/mixins.test.d.ts +2 -0
- package/utils/mixins.test.d.ts.map +1 -0
- package/utils/mixins.test.js +74 -0
- package/utils/mixins.test.js.map +1 -0
- package/utils/typed.d.ts +2 -0
- package/utils/typed.d.ts.map +1 -0
- package/utils/typed.js +7 -0
- package/utils/typed.js.map +1 -0
- package/.dependency-cruiser.js +0 -233
- package/.editorconfig +0 -12
- package/.eslintignore +0 -6
- package/.github/ISSUE_TEMPLATE/bug_report.md +0 -35
- package/.github/ISSUE_TEMPLATE/feature_request.md +0 -17
- package/.github/workflows/npm.yml +0 -17
- package/babel.config.js +0 -21
- package/build-docs.sh +0 -25
- package/docs/index.md +0 -9
- package/docs/typedoc/index.md +0 -11
- package/eslint.base.js +0 -232
- package/install.sh +0 -6
- package/jest.config.ts +0 -49
- package/nx.json +0 -39
- package/src/SiCard/BaseSiCard.test.ts +0 -187
- package/src/SiCard/BaseSiCard.ts +0 -101
- package/src/SiCard/IRaceResultData.ts +0 -16
- package/src/SiCard/ISiCard.ts +0 -23
- package/src/SiCard/ISiCardExamples.ts +0 -4
- package/src/SiCard/raceResultTools.test.ts +0 -260
- package/src/SiCard/raceResultTools.ts +0 -150
- package/src/SiCard/types/FCard.test.ts +0 -19
- package/src/SiCard/types/FCard.ts +0 -14
- package/src/SiCard/types/ModernSiCard.test.ts +0 -186
- package/src/SiCard/types/ModernSiCard.ts +0 -241
- package/src/SiCard/types/PCard.test.ts +0 -19
- package/src/SiCard/types/PCard.ts +0 -14
- package/src/SiCard/types/SIAC.test.ts +0 -84
- package/src/SiCard/types/SIAC.ts +0 -19
- package/src/SiCard/types/SiCard10.test.ts +0 -85
- package/src/SiCard/types/SiCard10.ts +0 -17
- package/src/SiCard/types/SiCard11.test.ts +0 -84
- package/src/SiCard/types/SiCard11.ts +0 -19
- package/src/SiCard/types/SiCard5.test.ts +0 -149
- package/src/SiCard/types/SiCard5.ts +0 -129
- package/src/SiCard/types/SiCard6.test.ts +0 -179
- package/src/SiCard/types/SiCard6.ts +0 -222
- package/src/SiCard/types/SiCard8.test.ts +0 -137
- package/src/SiCard/types/SiCard8.ts +0 -129
- package/src/SiCard/types/SiCard9.test.ts +0 -132
- package/src/SiCard/types/SiCard9.ts +0 -128
- package/src/SiCard/types/TCard.test.ts +0 -19
- package/src/SiCard/types/TCard.ts +0 -14
- package/src/SiCard/types/index.test.ts +0 -26
- package/src/SiCard/types/modernSiCardExamples.ts +0 -364
- package/src/SiCard/types/siCard5Examples.ts +0 -73
- package/src/SiCard/types/siCard6Examples.ts +0 -262
- package/src/SiCard/types/siCard8Examples.ts +0 -152
- package/src/SiCard/types/siCard9Examples.ts +0 -143
- package/src/SiDevice/INavigatorWebSerial.ts +0 -78
- package/src/SiDevice/INavigatorWebUsb.ts +0 -62
- package/src/SiDevice/ISiDevice.ts +0 -48
- package/src/SiDevice/ISiDeviceDriver.ts +0 -35
- package/src/SiDevice/README.md +0 -13
- package/src/SiDevice/SiDevice.test.ts +0 -354
- package/src/SiDevice/SiDevice.ts +0 -132
- package/src/SiDevice/WebSerialSiDeviceDriver.ts +0 -146
- package/src/SiDevice/WebUsbSiDeviceDriver.ts +0 -343
- package/src/SiDevice/testUtils/testISiDeviceDriver.ts +0 -63
- package/src/SiDevice/testUtils/testISiDeviceDriverWithAutodetection.ts +0 -72
- package/src/SiStation/BaseSiStation.test.ts +0 -221
- package/src/SiStation/BaseSiStation.ts +0 -253
- package/src/SiStation/CoupledSiStation.test.ts +0 -41
- package/src/SiStation/CoupledSiStation.ts +0 -130
- package/src/SiStation/ISiMainStation.ts +0 -29
- package/src/SiStation/ISiSendTask.ts +0 -9
- package/src/SiStation/ISiStation.ts +0 -88
- package/src/SiStation/ISiTargetMultiplexer.ts +0 -51
- package/src/SiStation/SiMainStation.test.ts +0 -222
- package/src/SiStation/SiMainStation.ts +0 -133
- package/src/SiStation/SiSendTask.ts +0 -50
- package/src/SiStation/SiTargetMultiplexer.targeting.test.ts +0 -112
- package/src/SiStation/SiTargetMultiplexer.test.ts +0 -605
- package/src/SiStation/SiTargetMultiplexer.ts +0 -241
- package/src/SiStation/siStationExamples.ts +0 -103
- package/src/constants.test.ts +0 -17
- package/src/constants.ts +0 -92
- package/src/fakes/FakeSiCard/BaseFakeSiCard.test.ts +0 -11
- package/src/fakes/FakeSiCard/BaseFakeSiCard.ts +0 -10
- package/src/fakes/FakeSiCard/IFakeSiCard.ts +0 -6
- package/src/fakes/FakeSiCard/types/FakeModernSiCard.test.ts +0 -62
- package/src/fakes/FakeSiCard/types/FakeModernSiCard.ts +0 -43
- package/src/fakes/FakeSiCard/types/FakeSIAC.ts +0 -17
- package/src/fakes/FakeSiCard/types/FakeSiCard10.ts +0 -17
- package/src/fakes/FakeSiCard/types/FakeSiCard11.ts +0 -17
- package/src/fakes/FakeSiCard/types/FakeSiCard5.test.ts +0 -42
- package/src/fakes/FakeSiCard/types/FakeSiCard5.ts +0 -40
- package/src/fakes/FakeSiCard/types/FakeSiCard6.test.ts +0 -62
- package/src/fakes/FakeSiCard/types/FakeSiCard6.ts +0 -44
- package/src/fakes/FakeSiCard/types/FakeSiCard8.ts +0 -16
- package/src/fakes/FakeSiCard/types/FakeSiCard9.ts +0 -16
- package/src/fakes/FakeSiDeviceDriver.ts +0 -148
- package/src/fakes/FakeSiMainStation.test.ts +0 -141
- package/src/fakes/FakeSiMainStation.ts +0 -118
- package/src/fakes/IFakeSiMainStation.ts +0 -15
- package/src/index.ts +0 -24
- package/src/siProtocol.test.ts +0 -509
- package/src/siProtocol.ts +0 -417
- package/src/storage/SiArray.test.ts +0 -103
- package/src/storage/SiArray.ts +0 -56
- package/src/storage/SiBool.test.ts +0 -81
- package/src/storage/SiBool.ts +0 -47
- package/src/storage/SiDataType.test.ts +0 -81
- package/src/storage/SiDataType.ts +0 -60
- package/src/storage/SiDict.test.ts +0 -115
- package/src/storage/SiDict.ts +0 -60
- package/src/storage/SiEnum.test.ts +0 -77
- package/src/storage/SiEnum.ts +0 -48
- package/src/storage/SiFieldValue.test.ts +0 -58
- package/src/storage/SiFieldValue.ts +0 -23
- package/src/storage/SiInt.test.ts +0 -80
- package/src/storage/SiInt.ts +0 -84
- package/src/storage/SiModified.test.ts +0 -135
- package/src/storage/SiModified.ts +0 -59
- package/src/storage/SiStorage.test.ts +0 -51
- package/src/storage/SiStorage.ts +0 -44
- package/src/storage/index.test.ts +0 -222
- package/src/storage/interfaces.ts +0 -41
- package/src/storage/siStringEncoding.ts +0 -1361
- package/src/testUtils.test.ts +0 -266
- package/src/testUtils.ts +0 -75
- package/src/utils/NumberRange.test.ts +0 -66
- package/src/utils/NumberRange.ts +0 -46
- package/src/utils/NumberRangeRegistry.test.ts +0 -49
- package/src/utils/NumberRangeRegistry.ts +0 -43
- package/src/utils/bytes.test.ts +0 -126
- package/src/utils/bytes.ts +0 -69
- package/src/utils/errors.test.ts +0 -29
- package/src/utils/errors.ts +0 -20
- package/src/utils/events.test.ts +0 -112
- package/src/utils/events.ts +0 -68
- package/src/utils/general.test.ts +0 -139
- package/src/utils/general.ts +0 -69
- package/src/utils/mixins.test.ts +0 -40
- package/src/utils/mixins.ts +0 -13
- package/src/utils/typed.ts +0 -3
- package/tsconfig.base.json +0 -22
- package/tsconfig.json +0 -15
|
@@ -1,222 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from '@jest/globals';
|
|
2
|
-
import _ from 'lodash';
|
|
3
|
-
import { proto } from '../constants';
|
|
4
|
-
import type * as siProtocol from '../siProtocol';
|
|
5
|
-
import * as testUtils from '../testUtils';
|
|
6
|
-
import type { ISiCard } from '../SiCard/ISiCard';
|
|
7
|
-
import type { ISiDevice, ISiDeviceDriverData } from '../SiDevice/ISiDevice';
|
|
8
|
-
import type { ISiDeviceDriver } from '../SiDevice/ISiDeviceDriver';
|
|
9
|
-
import { SiDevice } from '../SiDevice/SiDevice';
|
|
10
|
-
import { SiMainStationSiCardInsertedEvent, SiMainStationSiCardObservedEvent, SiMainStationSiCardRemovedEvent } from './ISiMainStation';
|
|
11
|
-
import { type ISiTargetMultiplexer, SiTargetMultiplexerMessageEvent, SiTargetMultiplexerTarget } from './ISiTargetMultiplexer';
|
|
12
|
-
import { SiTargetMultiplexer } from './SiTargetMultiplexer';
|
|
13
|
-
import { siStationStorageDefinition } from './BaseSiStation';
|
|
14
|
-
import { getBSM8Station } from './siStationExamples';
|
|
15
|
-
import { SiMainStation } from './SiMainStation';
|
|
16
|
-
import { getSiCard5Examples } from '../SiCard/types/siCard5Examples';
|
|
17
|
-
import { getSiCard6Examples } from '../SiCard/types/siCard6Examples';
|
|
18
|
-
import { FakeSiCard5 } from '../fakes/FakeSiCard/types/FakeSiCard5';
|
|
19
|
-
import { FakeSiCard6 } from '../fakes/FakeSiCard/types/FakeSiCard6';
|
|
20
|
-
|
|
21
|
-
testUtils.useFakeTimers();
|
|
22
|
-
|
|
23
|
-
function mockDriver(driver: Partial<ISiDeviceDriver<ISiDeviceDriverData<unknown>>>) {
|
|
24
|
-
return driver as unknown as ISiDeviceDriver<ISiDeviceDriverData<unknown>>;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
describe('SiMainStation', () => {
|
|
28
|
-
test('fromSiDevice', () => {
|
|
29
|
-
const fakeSiDevice = new SiDevice('fromSiDevice', {
|
|
30
|
-
driver: mockDriver({ name: 'FakeSiDevice' })
|
|
31
|
-
});
|
|
32
|
-
const myMainStation1 = SiMainStation.fromSiDevice(fakeSiDevice);
|
|
33
|
-
expect(myMainStation1 instanceof SiMainStation).toBe(true);
|
|
34
|
-
expect(myMainStation1.ident).toBe('Direct-FakeSiDevice-fromSiDevice');
|
|
35
|
-
expect(myMainStation1.multiplexerTarget).toBe(SiTargetMultiplexerTarget.Direct);
|
|
36
|
-
const myMainStation2 = SiMainStation.fromSiDevice(fakeSiDevice);
|
|
37
|
-
expect(myMainStation2).toBe(myMainStation1);
|
|
38
|
-
expect(myMainStation2.ident).toBe('Direct-FakeSiDevice-fromSiDevice');
|
|
39
|
-
expect(myMainStation2.multiplexerTarget).toBe(SiTargetMultiplexerTarget.Direct);
|
|
40
|
-
});
|
|
41
|
-
test('fromSiTargetMultiplexer', () => {
|
|
42
|
-
const myTargetMultiplexer = new SiTargetMultiplexer({ ident: 'fake-ident' } as ISiDevice<ISiDeviceDriverData<unknown>>);
|
|
43
|
-
const myMainStation1 = SiMainStation.fromSiTargetMultiplexer(myTargetMultiplexer);
|
|
44
|
-
expect(myMainStation1 instanceof SiMainStation).toBe(true);
|
|
45
|
-
expect(myMainStation1.ident).toBe('Direct-fake-ident');
|
|
46
|
-
expect(myMainStation1.multiplexerTarget).toBe(SiTargetMultiplexerTarget.Direct);
|
|
47
|
-
const myMainStation2 = SiMainStation.fromSiTargetMultiplexer(myTargetMultiplexer);
|
|
48
|
-
expect(myMainStation2).toBe(myMainStation1);
|
|
49
|
-
expect(myMainStation2.ident).toBe('Direct-fake-ident');
|
|
50
|
-
expect(myMainStation2.multiplexerTarget).toBe(SiTargetMultiplexerTarget.Direct);
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
test('can readCards', async () => {
|
|
54
|
-
const storage = siStationStorageDefinition(getBSM8Station().storageData);
|
|
55
|
-
storage.set('mode', 'Control');
|
|
56
|
-
storage.set('code', 31);
|
|
57
|
-
storage.set('autoSend', true);
|
|
58
|
-
storage.set('handshake', false);
|
|
59
|
-
storage.set('beeps', false);
|
|
60
|
-
storage.set('flashes', false);
|
|
61
|
-
const fakeSiTargetMultiplexer = {
|
|
62
|
-
addEventListener: () => undefined,
|
|
63
|
-
sendMessage: (_target: SiTargetMultiplexerTarget, message: siProtocol.SiMessage, _numResponses: number) => {
|
|
64
|
-
if (message.mode !== undefined) {
|
|
65
|
-
throw new Error();
|
|
66
|
-
}
|
|
67
|
-
if (message.command === proto.cmd.GET_SYS_VAL) {
|
|
68
|
-
return Promise.resolve([[0x00, 0x00, 0x00, ...storage.data]]);
|
|
69
|
-
}
|
|
70
|
-
if (message.command === proto.cmd.SET_SYS_VAL) {
|
|
71
|
-
storage.splice(message.parameters[0], message.parameters.length - 1, ...message.parameters.slice(1));
|
|
72
|
-
return Promise.resolve([[0x00, 0x00, message.parameters[0]]]);
|
|
73
|
-
}
|
|
74
|
-
throw new Error();
|
|
75
|
-
}
|
|
76
|
-
} as unknown as ISiTargetMultiplexer;
|
|
77
|
-
const mySiStation = new SiMainStation(fakeSiTargetMultiplexer);
|
|
78
|
-
const cardsRead: ISiCard[] = [];
|
|
79
|
-
const cleanUpFunction = await mySiStation.readCards((card) => {
|
|
80
|
-
cardsRead.push(card);
|
|
81
|
-
});
|
|
82
|
-
await testUtils.nTimesAsync(3, () => testUtils.advanceTimersByTime(0));
|
|
83
|
-
if (cleanUpFunction === undefined) {
|
|
84
|
-
throw new Error('expect cleanUp function');
|
|
85
|
-
}
|
|
86
|
-
expect(storage.get('mode')!.value).toBe('Readout');
|
|
87
|
-
expect(storage.get('code')!.value).toBe(10);
|
|
88
|
-
expect(storage.get('autoSend')!.value).toBe(false);
|
|
89
|
-
expect(storage.get('handshake')!.value).toBe(true);
|
|
90
|
-
expect(storage.get('beeps')!.value).toBe(true);
|
|
91
|
-
expect(storage.get('flashes')!.value).toBe(true);
|
|
92
|
-
|
|
93
|
-
const fakeSiCard = {
|
|
94
|
-
cardNumber: 1234
|
|
95
|
-
} as ISiCard;
|
|
96
|
-
mySiStation.dispatchEvent('siCardInserted', new SiMainStationSiCardInsertedEvent(mySiStation, fakeSiCard));
|
|
97
|
-
await testUtils.nTimesAsync(1, () => testUtils.advanceTimersByTime(0));
|
|
98
|
-
expect(cardsRead).toEqual([{ cardNumber: 1234 } as ISiCard]);
|
|
99
|
-
|
|
100
|
-
const actualCleanUpFunction: () => Promise<void> = cleanUpFunction;
|
|
101
|
-
await actualCleanUpFunction();
|
|
102
|
-
expect(storage.get('mode')!.value).toBe('Control');
|
|
103
|
-
expect(storage.get('code')!.value).toBe(31);
|
|
104
|
-
expect(storage.get('autoSend')!.value).toBe(true);
|
|
105
|
-
expect(storage.get('handshake')!.value).toBe(false);
|
|
106
|
-
expect(storage.get('beeps')!.value).toBe(false);
|
|
107
|
-
expect(storage.get('flashes')!.value).toBe(false);
|
|
108
|
-
|
|
109
|
-
mySiStation.dispatchEvent('siCardInserted', new SiMainStationSiCardInsertedEvent(mySiStation, fakeSiCard));
|
|
110
|
-
await testUtils.nTimesAsync(1, () => testUtils.advanceTimersByTime(0));
|
|
111
|
-
// No additional entry
|
|
112
|
-
expect(cardsRead).toEqual([{ cardNumber: 1234 } as ISiCard]);
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
test('card detection & removal', async () => {
|
|
116
|
-
const myTargetMultiplexer = new SiTargetMultiplexer({} as ISiDevice<ISiDeviceDriverData<unknown>>);
|
|
117
|
-
const myMainStation = SiMainStation.fromSiTargetMultiplexer(myTargetMultiplexer);
|
|
118
|
-
const testData = getSiCard5Examples().fullCard;
|
|
119
|
-
const myFakeSiCard5 = new FakeSiCard5(testData.storageData);
|
|
120
|
-
|
|
121
|
-
const insertedCardNumbers: number[] = [];
|
|
122
|
-
const handleCardInserted = (e: SiMainStationSiCardInsertedEvent) => {
|
|
123
|
-
insertedCardNumbers.push(e.siCard.cardNumber);
|
|
124
|
-
};
|
|
125
|
-
myMainStation.addEventListener('siCardInserted', handleCardInserted);
|
|
126
|
-
const message = myFakeSiCard5.handleDetect() as siProtocol.SiMessageWithoutMode;
|
|
127
|
-
myTargetMultiplexer.dispatchEvent(
|
|
128
|
-
'message',
|
|
129
|
-
new SiTargetMultiplexerMessageEvent(myTargetMultiplexer, {
|
|
130
|
-
command: message.command,
|
|
131
|
-
parameters: [...[0x00, 0x00], ...message.parameters] as number[]
|
|
132
|
-
})
|
|
133
|
-
);
|
|
134
|
-
await testUtils.nTimesAsync(2, () => testUtils.advanceTimersByTime(0));
|
|
135
|
-
expect(insertedCardNumbers).toEqual([406402]);
|
|
136
|
-
|
|
137
|
-
const removedCardNumbers: number[] = [];
|
|
138
|
-
const handleCardRemoved = (e: SiMainStationSiCardRemovedEvent) => {
|
|
139
|
-
removedCardNumbers.push(e.siCard.cardNumber);
|
|
140
|
-
};
|
|
141
|
-
myMainStation.addEventListener('siCardRemoved', handleCardRemoved);
|
|
142
|
-
myTargetMultiplexer.dispatchEvent(
|
|
143
|
-
'message',
|
|
144
|
-
new SiTargetMultiplexerMessageEvent(myTargetMultiplexer, {
|
|
145
|
-
command: proto.cmd.SI_REM,
|
|
146
|
-
parameters: [...[0x00, 0x00], ...message.parameters] as number[]
|
|
147
|
-
})
|
|
148
|
-
);
|
|
149
|
-
await testUtils.nTimesAsync(2, () => testUtils.advanceTimersByTime(0));
|
|
150
|
-
expect(removedCardNumbers).toEqual([406402]);
|
|
151
|
-
|
|
152
|
-
myTargetMultiplexer.dispatchEvent(
|
|
153
|
-
'message',
|
|
154
|
-
new SiTargetMultiplexerMessageEvent(myTargetMultiplexer, {
|
|
155
|
-
command: proto.cmd.SI_REM,
|
|
156
|
-
parameters: [0x00, 0x00, 0x01, 0x23, 0x45, 0x67]
|
|
157
|
-
})
|
|
158
|
-
);
|
|
159
|
-
await testUtils.nTimesAsync(2, () => testUtils.advanceTimersByTime(0));
|
|
160
|
-
expect(removedCardNumbers).toEqual([406402]);
|
|
161
|
-
|
|
162
|
-
myMainStation.removeEventListener('siCardInserted', handleCardInserted);
|
|
163
|
-
myMainStation.removeEventListener('siCardRemoved', handleCardRemoved);
|
|
164
|
-
});
|
|
165
|
-
test('card observation', async () => {
|
|
166
|
-
const myTargetMultiplexer = new SiTargetMultiplexer({} as ISiDevice<ISiDeviceDriverData<unknown>>);
|
|
167
|
-
const myMainStation = SiMainStation.fromSiTargetMultiplexer(myTargetMultiplexer);
|
|
168
|
-
const testData = getSiCard6Examples().fullCard;
|
|
169
|
-
const myFakeSiCard6 = new FakeSiCard6(testData.storageData);
|
|
170
|
-
const observedCardNumbers: number[] = [];
|
|
171
|
-
const handleCardObserved = (e: SiMainStationSiCardObservedEvent) => {
|
|
172
|
-
observedCardNumbers.push(e.siCard.cardNumber);
|
|
173
|
-
};
|
|
174
|
-
myMainStation.addEventListener('siCardObserved', handleCardObserved);
|
|
175
|
-
const message = myFakeSiCard6.handleDetect() as siProtocol.SiMessageWithoutMode;
|
|
176
|
-
myTargetMultiplexer.dispatchEvent(
|
|
177
|
-
'message',
|
|
178
|
-
new SiTargetMultiplexerMessageEvent(myTargetMultiplexer, {
|
|
179
|
-
command: proto.cmd.TRANS_REC,
|
|
180
|
-
parameters: [...[0x00, 0x00], ...message.parameters] as number[]
|
|
181
|
-
})
|
|
182
|
-
);
|
|
183
|
-
|
|
184
|
-
await testUtils.nTimesAsync(2, () => testUtils.advanceTimersByTime(0));
|
|
185
|
-
expect(observedCardNumbers).toEqual([testData.cardData.cardNumber]);
|
|
186
|
-
});
|
|
187
|
-
test('card observation with mode', async () => {
|
|
188
|
-
const myTargetMultiplexer = new SiTargetMultiplexer({} as ISiDevice<ISiDeviceDriverData<unknown>>);
|
|
189
|
-
const myMainStation = SiMainStation.fromSiTargetMultiplexer(myTargetMultiplexer);
|
|
190
|
-
const observedCardNumbers: number[] = [];
|
|
191
|
-
const handleCardObserved = (e: SiMainStationSiCardObservedEvent) => {
|
|
192
|
-
observedCardNumbers.push(e.siCard.cardNumber);
|
|
193
|
-
};
|
|
194
|
-
myMainStation.addEventListener('siCardObserved', handleCardObserved);
|
|
195
|
-
myTargetMultiplexer.dispatchEvent('message', new SiTargetMultiplexerMessageEvent(myTargetMultiplexer, { mode: proto.NAK }));
|
|
196
|
-
|
|
197
|
-
await testUtils.nTimesAsync(2, () => testUtils.advanceTimersByTime(0));
|
|
198
|
-
expect(observedCardNumbers).toEqual([]);
|
|
199
|
-
});
|
|
200
|
-
test('other message', () => {
|
|
201
|
-
const fakeSiTargetMultiplexer = {
|
|
202
|
-
addEventListener: () => undefined,
|
|
203
|
-
sendMessage: () => Promise.resolve([])
|
|
204
|
-
} as unknown as ISiTargetMultiplexer;
|
|
205
|
-
const mySiStation = new SiMainStation(fakeSiTargetMultiplexer);
|
|
206
|
-
mySiStation.handleMessage({ command: proto.cmd.SIGNAL, parameters: [0x01] });
|
|
207
|
-
});
|
|
208
|
-
|
|
209
|
-
test('sendMessage', async () => {
|
|
210
|
-
const fakeSiTargetMultiplexer = {
|
|
211
|
-
addEventListener: () => undefined,
|
|
212
|
-
sendMessage: () => Promise.resolve([])
|
|
213
|
-
} as unknown as ISiTargetMultiplexer;
|
|
214
|
-
const mySiStation = new SiMainStation(fakeSiTargetMultiplexer);
|
|
215
|
-
let sendMessageSucceeded:boolean|undefined = undefined;
|
|
216
|
-
mySiStation.sendMessage({} as siProtocol.SiMessage).then(() => {
|
|
217
|
-
sendMessageSucceeded = true;
|
|
218
|
-
});
|
|
219
|
-
await testUtils.nTimesAsync(1, () => testUtils.advanceTimersByTime(0));
|
|
220
|
-
expect(sendMessageSucceeded).toBe(true);
|
|
221
|
-
});
|
|
222
|
-
});
|
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import * as utils from '../utils';
|
|
2
|
-
import * as siProtocol from '../siProtocol';
|
|
3
|
-
import { proto } from '../constants';
|
|
4
|
-
import { BaseSiCard } from '../SiCard';
|
|
5
|
-
import type { ISiCard } from '../SiCard/ISiCard';
|
|
6
|
-
import type { ISiDevice, ISiDeviceDriverData } from '../SiDevice/ISiDevice';
|
|
7
|
-
import type { ISiStation } from './ISiStation';
|
|
8
|
-
import { type SiMainStationEvents, SiMainStationSiCardInsertedEvent, SiMainStationSiCardObservedEvent, SiMainStationSiCardRemovedEvent } from './ISiMainStation';
|
|
9
|
-
import { type ISiTargetMultiplexer, SiTargetMultiplexerMessageEvent, SiTargetMultiplexerTarget } from './ISiTargetMultiplexer';
|
|
10
|
-
import { BaseSiStation, type ISiStationStorageFields } from './BaseSiStation';
|
|
11
|
-
import { SiTargetMultiplexer } from './SiTargetMultiplexer';
|
|
12
|
-
|
|
13
|
-
type SiStationSetup = {
|
|
14
|
-
[key in keyof ISiStationStorageFields]?: ISiStationStorageFields[key];
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
type CleanUpFunction = () => Promise<void>;
|
|
18
|
-
|
|
19
|
-
export class SiMainStation extends BaseSiStation<SiTargetMultiplexerTarget.Direct> implements ISiStation<SiTargetMultiplexerTarget.Direct> {
|
|
20
|
-
static fromSiDevice(siDevice: ISiDevice<ISiDeviceDriverData<unknown>>): SiMainStation {
|
|
21
|
-
const multiplexer = SiTargetMultiplexer.fromSiDevice(siDevice);
|
|
22
|
-
return this.fromSiTargetMultiplexer(multiplexer);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
static fromSiTargetMultiplexer(multiplexer: ISiTargetMultiplexer): SiMainStation {
|
|
26
|
-
return this.fromSiTargetMultiplexerWithGivenTarget(multiplexer, SiTargetMultiplexerTarget.Direct, () => new this(multiplexer, SiTargetMultiplexerTarget.Direct)) as SiMainStation;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
public siCard: ISiCard | null = null;
|
|
30
|
-
|
|
31
|
-
constructor(siTargetMultiplexer: ISiTargetMultiplexer, multiplexerTarget: SiTargetMultiplexerTarget.Direct = SiTargetMultiplexerTarget.Direct) {
|
|
32
|
-
super(siTargetMultiplexer, multiplexerTarget);
|
|
33
|
-
siTargetMultiplexer.addEventListener(
|
|
34
|
-
'message', // not directMessage, as the target might still be unknown, but we still need the message
|
|
35
|
-
(e: SiTargetMultiplexerMessageEvent) => {
|
|
36
|
-
const message = e.message;
|
|
37
|
-
this.handleMessage(message);
|
|
38
|
-
console.log(`There's a SiMainStation listening to this ${message}`);
|
|
39
|
-
}
|
|
40
|
-
);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
readCards(onCardInserted: (card: ISiCard) => void, siStationSetupModification: SiStationSetup = {}): Promise<CleanUpFunction> {
|
|
44
|
-
const siStationSetup: SiStationSetup = {
|
|
45
|
-
code: 10,
|
|
46
|
-
mode: 'Readout',
|
|
47
|
-
autoSend: false,
|
|
48
|
-
handshake: true,
|
|
49
|
-
beeps: true,
|
|
50
|
-
flashes: true,
|
|
51
|
-
...siStationSetupModification
|
|
52
|
-
};
|
|
53
|
-
const siStationSetupKeys = Object.keys(siStationSetup) as (keyof ISiStationStorageFields)[];
|
|
54
|
-
const oldState: SiStationSetup = {};
|
|
55
|
-
|
|
56
|
-
const handleCardInserted = (e: SiMainStationSiCardInsertedEvent) => {
|
|
57
|
-
onCardInserted(e.siCard);
|
|
58
|
-
};
|
|
59
|
-
|
|
60
|
-
const cleanUp: CleanUpFunction = () => {
|
|
61
|
-
this.removeEventListener('siCardInserted', handleCardInserted);
|
|
62
|
-
return this.atomically(() => {
|
|
63
|
-
siStationSetupKeys.forEach((infoName) => {
|
|
64
|
-
const oldInfoValue = oldState[infoName];
|
|
65
|
-
if (oldInfoValue !== undefined) {
|
|
66
|
-
this.setInfo(infoName, oldInfoValue);
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
return this.atomically(() => {
|
|
73
|
-
siStationSetupKeys.forEach((infoName: keyof ISiStationStorageFields) => {
|
|
74
|
-
const oldFieldValue = this.getInfo(infoName);
|
|
75
|
-
// @ts-ignore
|
|
76
|
-
oldState[infoName] = oldFieldValue ? oldFieldValue.value : undefined;
|
|
77
|
-
const newValue = siStationSetup[infoName];
|
|
78
|
-
if (newValue !== undefined) {
|
|
79
|
-
this.setInfo(infoName, newValue);
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
|
-
}).then(() => {
|
|
83
|
-
this.addEventListener('siCardInserted', handleCardInserted);
|
|
84
|
-
return cleanUp;
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
handleMessage(message: siProtocol.SiMessage): void {
|
|
89
|
-
if (message.mode !== undefined) {
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
const { command, parameters } = message;
|
|
93
|
-
const detectedSiCard = BaseSiCard.detectFromMessage(message);
|
|
94
|
-
if (detectedSiCard !== undefined) {
|
|
95
|
-
detectedSiCard.mainStation = this;
|
|
96
|
-
this.siCard = detectedSiCard as ISiCard;
|
|
97
|
-
this.dispatchEvent('siCardInserted', new SiMainStationSiCardInsertedEvent(this, detectedSiCard as ISiCard));
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
const handleSiCardRemoved = () => {
|
|
101
|
-
const removedCardNumber = siProtocol.arr2cardNumber([parameters[5], parameters[4], parameters[3]]); // TODO: also [2]?
|
|
102
|
-
if (this.siCard !== null && this.siCard.cardNumber === removedCardNumber) {
|
|
103
|
-
this.dispatchEvent('siCardRemoved', new SiMainStationSiCardRemovedEvent(this, this.siCard));
|
|
104
|
-
} else {
|
|
105
|
-
console.warn(`Card ${removedCardNumber} was removed, but never inserted`);
|
|
106
|
-
}
|
|
107
|
-
this.siCard = null;
|
|
108
|
-
};
|
|
109
|
-
const handleSiCardObserved = () => {
|
|
110
|
-
const observedCardNumber = siProtocol.arr2cardNumber([parameters[5], parameters[4], parameters[3]]); // TODO: also [2]?
|
|
111
|
-
if (observedCardNumber === undefined) {
|
|
112
|
-
return;
|
|
113
|
-
}
|
|
114
|
-
const transRecordCard = BaseSiCard.fromCardNumber(observedCardNumber);
|
|
115
|
-
if (transRecordCard !== undefined) {
|
|
116
|
-
transRecordCard.mainStation = this;
|
|
117
|
-
this.dispatchEvent('siCardObserved', new SiMainStationSiCardObservedEvent(this, transRecordCard as ISiCard));
|
|
118
|
-
}
|
|
119
|
-
};
|
|
120
|
-
const handlerByCommand: { [command: number]: () => void } = {
|
|
121
|
-
[proto.cmd.SI_REM]: handleSiCardRemoved,
|
|
122
|
-
[proto.cmd.TRANS_REC]: handleSiCardObserved
|
|
123
|
-
};
|
|
124
|
-
const handler = handlerByCommand[command];
|
|
125
|
-
if (handler === undefined) {
|
|
126
|
-
return;
|
|
127
|
-
}
|
|
128
|
-
handler();
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-interface
|
|
132
|
-
export interface SiMainStation extends utils.EventTarget<SiMainStationEvents> {}
|
|
133
|
-
utils.applyMixins(SiMainStation, [utils.EventTarget]);
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import * as siProtocol from '../siProtocol';
|
|
2
|
-
import { SiSendTaskState } from './ISiSendTask';
|
|
3
|
-
|
|
4
|
-
export class SiSendTask {
|
|
5
|
-
public state: SiSendTaskState = SiSendTaskState.Queued;
|
|
6
|
-
public responses: number[][] = [];
|
|
7
|
-
private timeoutTimer: unknown;
|
|
8
|
-
|
|
9
|
-
constructor(
|
|
10
|
-
public message: siProtocol.SiMessage,
|
|
11
|
-
public numResponses: number,
|
|
12
|
-
public timeoutInMiliseconds: number,
|
|
13
|
-
public onResolve: (task: SiSendTask) => void,
|
|
14
|
-
public onReject: (task: SiSendTask) => void
|
|
15
|
-
) {
|
|
16
|
-
this.timeoutTimer = setTimeout(() => {
|
|
17
|
-
const shouldAbortInState: { [state in SiSendTaskState]: boolean } = {
|
|
18
|
-
[SiSendTaskState.Queued]: true,
|
|
19
|
-
[SiSendTaskState.Sending]: true,
|
|
20
|
-
[SiSendTaskState.Sent]: true,
|
|
21
|
-
[SiSendTaskState.Succeeded]: false,
|
|
22
|
-
[SiSendTaskState.Failed]: false
|
|
23
|
-
};
|
|
24
|
-
if (!shouldAbortInState[this.state]) {
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
console.debug(`Timeout: ${siProtocol.prettyMessage(this.message)} (expected ${this.numResponses} responses)`, this.responses);
|
|
28
|
-
this.fail();
|
|
29
|
-
}, timeoutInMiliseconds);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
addResponse(response: number[]): void {
|
|
33
|
-
this.responses.push(response);
|
|
34
|
-
if (this.responses.length === this.numResponses) {
|
|
35
|
-
this.succeed();
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
succeed(): void {
|
|
40
|
-
this.state = SiSendTaskState.Succeeded;
|
|
41
|
-
clearTimeout(this.timeoutTimer as Parameters<typeof clearTimeout>[0]);
|
|
42
|
-
this.onResolve(this);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
fail(): void {
|
|
46
|
-
this.state = SiSendTaskState.Failed;
|
|
47
|
-
clearTimeout(this.timeoutTimer as Parameters<typeof clearTimeout>[0]);
|
|
48
|
-
this.onReject(this);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from '@jest/globals';
|
|
2
|
-
import { proto } from '../constants';
|
|
3
|
-
import * as siProtocol from '../siProtocol';
|
|
4
|
-
import * as testUtils from '../testUtils';
|
|
5
|
-
import { SiDevice } from '../SiDevice/SiDevice';
|
|
6
|
-
import { SiDeviceState, SiDeviceReceiveEvent, type ISiDeviceDriverData } from '../SiDevice/ISiDevice';
|
|
7
|
-
import type { ISiDeviceDriver } from '../SiDevice/ISiDeviceDriver';
|
|
8
|
-
import { SiTargetMultiplexerTarget } from './ISiTargetMultiplexer';
|
|
9
|
-
import { SiTargetMultiplexer } from './SiTargetMultiplexer';
|
|
10
|
-
|
|
11
|
-
testUtils.useFakeTimers();
|
|
12
|
-
|
|
13
|
-
function mockDriver(driver: Partial<ISiDeviceDriver<ISiDeviceDriverData<unknown>>>) {
|
|
14
|
-
return driver as unknown as ISiDeviceDriver<ISiDeviceDriverData<unknown>>;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
describe('SiTargetMultiplexer', () => {
|
|
18
|
-
test('handles targeting', async () => {
|
|
19
|
-
const siDevice = new SiDevice('handlesTargeting0', {
|
|
20
|
-
driver: mockDriver({
|
|
21
|
-
send: () => Promise.resolve()
|
|
22
|
-
})
|
|
23
|
-
});
|
|
24
|
-
siDevice.setState(SiDeviceState.Opened);
|
|
25
|
-
const muxer = SiTargetMultiplexer.fromSiDevice(siDevice);
|
|
26
|
-
expect(muxer instanceof SiTargetMultiplexer).toBe(true);
|
|
27
|
-
|
|
28
|
-
const randomMessage = testUtils.getRandomMessage({});
|
|
29
|
-
const timeState = {
|
|
30
|
-
sendingFinished: false,
|
|
31
|
-
resendingFinished: false,
|
|
32
|
-
remoteSendingFinished: false
|
|
33
|
-
};
|
|
34
|
-
muxer.sendMessage(SiTargetMultiplexerTarget.Direct, randomMessage, 0, 1).then((responses) => {
|
|
35
|
-
expect(responses.length).toBe(0);
|
|
36
|
-
expect(muxer._test.sendQueue.length).toBe(0);
|
|
37
|
-
timeState.sendingFinished = true;
|
|
38
|
-
});
|
|
39
|
-
setTimeout(() => {
|
|
40
|
-
siDevice.dispatchEvent(
|
|
41
|
-
'receive',
|
|
42
|
-
new SiDeviceReceiveEvent(
|
|
43
|
-
siDevice,
|
|
44
|
-
siProtocol.render({
|
|
45
|
-
command: proto.cmd.SET_MS,
|
|
46
|
-
parameters: [0x00, 0x00, proto.P_MS_DIRECT]
|
|
47
|
-
})
|
|
48
|
-
)
|
|
49
|
-
);
|
|
50
|
-
}, 1);
|
|
51
|
-
expect(muxer.target).toBe(SiTargetMultiplexerTarget.Unknown);
|
|
52
|
-
expect(muxer._test.latestTarget).toBe(SiTargetMultiplexerTarget.Direct);
|
|
53
|
-
await testUtils.advanceTimersByTime(0); // resolve setTarget send promise
|
|
54
|
-
await testUtils.advanceTimersByTime(1); // trigger setTarget receive
|
|
55
|
-
await testUtils.nTimesAsync(10, () => testUtils.advanceTimersByTime(1));
|
|
56
|
-
expect(muxer.target).toBe(SiTargetMultiplexerTarget.Direct);
|
|
57
|
-
expect(muxer._test.latestTarget).toBe(SiTargetMultiplexerTarget.Direct);
|
|
58
|
-
await testUtils.advanceTimersByTime(0);
|
|
59
|
-
await testUtils.advanceTimersByTime(0);
|
|
60
|
-
expect(timeState).toEqual({
|
|
61
|
-
sendingFinished: true,
|
|
62
|
-
resendingFinished: false,
|
|
63
|
-
remoteSendingFinished: false
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
muxer.sendMessage(SiTargetMultiplexerTarget.Direct, randomMessage, 0, 1).then((responses) => {
|
|
67
|
-
expect(responses.length).toBe(0);
|
|
68
|
-
expect(muxer._test.sendQueue.length).toBe(0);
|
|
69
|
-
timeState.resendingFinished = true;
|
|
70
|
-
});
|
|
71
|
-
await testUtils.advanceTimersByTime(0);
|
|
72
|
-
await testUtils.advanceTimersByTime(0);
|
|
73
|
-
expect(muxer.target).toBe(SiTargetMultiplexerTarget.Direct);
|
|
74
|
-
expect(muxer._test.latestTarget).toBe(SiTargetMultiplexerTarget.Direct);
|
|
75
|
-
expect(timeState).toEqual({
|
|
76
|
-
sendingFinished: true,
|
|
77
|
-
resendingFinished: true,
|
|
78
|
-
remoteSendingFinished: false
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
muxer.sendMessage(SiTargetMultiplexerTarget.Remote, randomMessage, 0, 1).then((responses) => {
|
|
82
|
-
expect(responses.length).toBe(0);
|
|
83
|
-
expect(muxer._test.sendQueue.length).toBe(0);
|
|
84
|
-
timeState.remoteSendingFinished = true;
|
|
85
|
-
});
|
|
86
|
-
setTimeout(() => {
|
|
87
|
-
siDevice.dispatchEvent(
|
|
88
|
-
'receive',
|
|
89
|
-
new SiDeviceReceiveEvent(
|
|
90
|
-
siDevice,
|
|
91
|
-
siProtocol.render({
|
|
92
|
-
command: proto.cmd.SET_MS,
|
|
93
|
-
parameters: [0x00, 0x00, proto.P_MS_REMOTE]
|
|
94
|
-
})
|
|
95
|
-
)
|
|
96
|
-
);
|
|
97
|
-
}, 1);
|
|
98
|
-
expect(muxer.target).toBe(SiTargetMultiplexerTarget.Direct);
|
|
99
|
-
expect(muxer._test.latestTarget).toBe(SiTargetMultiplexerTarget.Remote);
|
|
100
|
-
await testUtils.advanceTimersByTime(0); // resolve setTarget send promise
|
|
101
|
-
await testUtils.advanceTimersByTime(1); // trigger setTarget receive
|
|
102
|
-
expect(muxer.target).toBe(SiTargetMultiplexerTarget.Remote);
|
|
103
|
-
expect(muxer._test.latestTarget).toBe(SiTargetMultiplexerTarget.Remote);
|
|
104
|
-
await testUtils.advanceTimersByTime(0);
|
|
105
|
-
await testUtils.advanceTimersByTime(0);
|
|
106
|
-
expect(timeState).toEqual({
|
|
107
|
-
sendingFinished: true,
|
|
108
|
-
resendingFinished: true,
|
|
109
|
-
remoteSendingFinished: true
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
});
|