data.spec.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. import Data from '../../../src/dom/data.js'
  2. import { clearFixture, getFixture } from '../../helpers/fixture.js'
  3. describe('Data', () => {
  4. const TEST_KEY = 'bs.test'
  5. const UNKNOWN_KEY = 'bs.unknown'
  6. const TEST_DATA = {
  7. test: 'bsData'
  8. }
  9. let fixtureEl
  10. let div
  11. beforeAll(() => {
  12. fixtureEl = getFixture()
  13. })
  14. beforeEach(() => {
  15. fixtureEl.innerHTML = '<div></div>'
  16. div = fixtureEl.querySelector('div')
  17. })
  18. afterEach(() => {
  19. Data.remove(div, TEST_KEY)
  20. clearFixture()
  21. })
  22. it('should return null for unknown elements', () => {
  23. const data = { ...TEST_DATA }
  24. Data.set(div, TEST_KEY, data)
  25. expect(Data.get(null)).toBeNull()
  26. expect(Data.get(undefined)).toBeNull()
  27. expect(Data.get(document.createElement('div'), TEST_KEY)).toBeNull()
  28. })
  29. it('should return null for unknown keys', () => {
  30. const data = { ...TEST_DATA }
  31. Data.set(div, TEST_KEY, data)
  32. expect(Data.get(div, null)).toBeNull()
  33. expect(Data.get(div, undefined)).toBeNull()
  34. expect(Data.get(div, UNKNOWN_KEY)).toBeNull()
  35. })
  36. it('should store data for an element with a given key and return it', () => {
  37. const data = { ...TEST_DATA }
  38. Data.set(div, TEST_KEY, data)
  39. expect(Data.get(div, TEST_KEY)).toEqual(data)
  40. })
  41. it('should overwrite data if something is already stored', () => {
  42. const data = { ...TEST_DATA }
  43. const copy = { ...data }
  44. Data.set(div, TEST_KEY, data)
  45. Data.set(div, TEST_KEY, copy)
  46. // Using `toBe` since spread creates a shallow copy
  47. expect(Data.get(div, TEST_KEY)).not.toBe(data)
  48. expect(Data.get(div, TEST_KEY)).toBe(copy)
  49. })
  50. it('should do nothing when an element has nothing stored', () => {
  51. Data.remove(div, TEST_KEY)
  52. expect().nothing()
  53. })
  54. it('should remove nothing for an unknown key', () => {
  55. const data = { ...TEST_DATA }
  56. Data.set(div, TEST_KEY, data)
  57. Data.remove(div, UNKNOWN_KEY)
  58. expect(Data.get(div, TEST_KEY)).toEqual(data)
  59. })
  60. it('should remove data for a given key', () => {
  61. const data = { ...TEST_DATA }
  62. Data.set(div, TEST_KEY, data)
  63. Data.remove(div, TEST_KEY)
  64. expect(Data.get(div, TEST_KEY)).toBeNull()
  65. })
  66. it('should console.error a message if called with multiple keys', () => {
  67. console.error = jasmine.createSpy('console.error')
  68. const data = { ...TEST_DATA }
  69. const copy = { ...data }
  70. Data.set(div, TEST_KEY, data)
  71. Data.set(div, UNKNOWN_KEY, copy)
  72. expect(console.error).toHaveBeenCalled()
  73. expect(Data.get(div, UNKNOWN_KEY)).toBeNull()
  74. })
  75. })