mirror of
https://github.com/BoostIo/Boostnote
synced 2025-12-13 09:46:22 +00:00
The root cause of this issue is that when the folder is clicked, the router pushed the path and the StorageItem component has been refreshed and isOpen has been reset - Add storing collapse state for storage - Add tests - Default as collapsed for fallback fix BoostIo/Boostnote#1979 BoostIo/Boostnote#1911
39 lines
1.2 KiB
JavaScript
39 lines
1.2 KiB
JavaScript
const test = require('ava')
|
|
const toggleStorage = require('browser/main/lib/dataApi/toggleStorage')
|
|
|
|
global.document = require('jsdom').jsdom('<body></body>')
|
|
global.window = document.defaultView
|
|
global.navigator = window.navigator
|
|
|
|
const Storage = require('dom-storage')
|
|
const localStorage = window.localStorage = global.localStorage = new Storage(null, { strict: true })
|
|
const path = require('path')
|
|
const _ = require('lodash')
|
|
const TestDummy = require('../fixtures/TestDummy')
|
|
const sander = require('sander')
|
|
const os = require('os')
|
|
|
|
const storagePath = path.join(os.tmpdir(), 'test/toggle-storage')
|
|
|
|
test.beforeEach((t) => {
|
|
t.context.storage = TestDummy.dummyStorage(storagePath)
|
|
localStorage.setItem('storages', JSON.stringify([t.context.storage.cache]))
|
|
})
|
|
|
|
test.serial('Toggle a storage location', (t) => {
|
|
const storageKey = t.context.storage.cache.key
|
|
return Promise.resolve()
|
|
.then(function doTest () {
|
|
return toggleStorage(storageKey, true)
|
|
})
|
|
.then(function assert (data) {
|
|
const cachedStorageList = JSON.parse(localStorage.getItem('storages'))
|
|
t.true(_.find(cachedStorageList, {key: storageKey}).isOpen === true)
|
|
})
|
|
})
|
|
|
|
test.after(function after () {
|
|
localStorage.clear()
|
|
sander.rimrafSync(storagePath)
|
|
})
|