data.spec.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. import Data from '../../../src/dom/data'
  2. /** Test helpers */
  3. import { getFixture, clearFixture } from '../../helpers/fixture'
  4. describe('Data', () => {
  5. const TEST_KEY = 'bs.test'
  6. const UNKNOWN_KEY = 'bs.unknown'
  7. const TEST_DATA = {
  8. test: 'bsData'
  9. }
  10. let fixtureEl
  11. let div
  12. beforeAll(() => {
  13. fixtureEl = getFixture()
  14. })
  15. beforeEach(() => {
  16. fixtureEl.innerHTML = '<div></div>'
  17. div = fixtureEl.querySelector('div')
  18. })
  19. afterEach(() => {
  20. Data.remove(div, TEST_KEY)
  21. clearFixture()
  22. })
  23. it('should return null for unknown elements', () => {
  24. const data = { ...TEST_DATA }
  25. Data.set(div, TEST_KEY, data)
  26. expect(Data.get(null)).toBeNull()
  27. expect(Data.get(undefined)).toBeNull()
  28. expect(Data.get(document.createElement('div'), TEST_KEY)).toBeNull()
  29. })
  30. it('should return null for unknown keys', () => {
  31. const data = { ...TEST_DATA }
  32. Data.set(div, TEST_KEY, data)
  33. expect(Data.get(div, null)).toBeNull()
  34. expect(Data.get(div, undefined)).toBeNull()
  35. expect(Data.get(div, UNKNOWN_KEY)).toBeNull()
  36. })
  37. it('should store data for an element with a given key and return it', () => {
  38. const data = { ...TEST_DATA }
  39. Data.set(div, TEST_KEY, data)
  40. expect(Data.get(div, TEST_KEY)).toBe(data)
  41. })
  42. it('should overwrite data if something is already stored', () => {
  43. const data = { ...TEST_DATA }
  44. const copy = { ...data }
  45. Data.set(div, TEST_KEY, data)
  46. Data.set(div, TEST_KEY, 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 have 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)).toBe(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. /* eslint-disable no-console */
  68. console.error = jasmine.createSpy('console.error')
  69. const data = { ...TEST_DATA }
  70. const copy = { ...data }
  71. Data.set(div, TEST_KEY, data)
  72. Data.set(div, UNKNOWN_KEY, copy)
  73. expect(console.error).toHaveBeenCalled()
  74. expect(Data.get(div, UNKNOWN_KEY)).toBe(null)
  75. })
  76. })