2023-03-29 19:49:30 +02:00
import Config from '../../../src/util/config.js'
import { clearFixture , getFixture } from '../../helpers/fixture.js'
2021-12-10 17:18:18 +01:00
class DummyConfigClass extends Config {
static get NAME ( ) {
return 'dummy'
}
}
describe ( 'Config' , ( ) => {
2022-04-21 20:41:43 +02:00
let fixtureEl
2021-12-10 17:18:18 +01:00
const name = 'dummy'
2022-04-21 20:41:43 +02:00
beforeAll ( ( ) => {
fixtureEl = getFixture ( )
} )
afterEach ( ( ) => {
clearFixture ( )
} )
2021-12-10 17:18:18 +01:00
describe ( 'NAME' , ( ) => {
it ( 'should return plugin NAME' , ( ) => {
expect ( DummyConfigClass . NAME ) . toEqual ( name )
} )
} )
describe ( 'DefaultType' , ( ) => {
it ( 'should return plugin default type' , ( ) => {
expect ( DummyConfigClass . DefaultType ) . toEqual ( jasmine . any ( Object ) )
} )
} )
describe ( 'Default' , ( ) => {
it ( 'should return plugin defaults' , ( ) => {
expect ( DummyConfigClass . Default ) . toEqual ( jasmine . any ( Object ) )
} )
} )
2022-04-21 20:41:43 +02:00
describe ( 'mergeConfigObj' , ( ) => {
it ( 'should parse element\'s data attributes and merge it with default config. Element\'s data attributes must excel Defaults' , ( ) => {
fixtureEl . innerHTML = '<div id="test" data-bs-test-bool="false" data-bs-test-int="8" data-bs-test-string1="bar"></div>'
spyOnProperty ( DummyConfigClass , 'Default' , 'get' ) . and . returnValue ( {
testBool : true ,
testString : 'foo' ,
testString1 : 'foo' ,
testInt : 7
} )
const instance = new DummyConfigClass ( )
const configResult = instance . _mergeConfigObj ( { } , fixtureEl . querySelector ( '#test' ) )
expect ( configResult . testBool ) . toEqual ( false )
expect ( configResult . testString ) . toEqual ( 'foo' )
expect ( configResult . testString1 ) . toEqual ( 'bar' )
expect ( configResult . testInt ) . toEqual ( 8 )
} )
it ( 'should parse element\'s data attributes and merge it with default config, plug these given during method call. The programmatically given should excel all' , ( ) => {
fixtureEl . innerHTML = '<div id="test" data-bs-test-bool="false" data-bs-test-int="8" data-bs-test-string-1="bar"></div>'
spyOnProperty ( DummyConfigClass , 'Default' , 'get' ) . and . returnValue ( {
testBool : true ,
testString : 'foo' ,
testString1 : 'foo' ,
testInt : 7
} )
const instance = new DummyConfigClass ( )
const configResult = instance . _mergeConfigObj ( {
testString1 : 'test' ,
testInt : 3
} , fixtureEl . querySelector ( '#test' ) )
expect ( configResult . testBool ) . toEqual ( false )
expect ( configResult . testString ) . toEqual ( 'foo' )
expect ( configResult . testString1 ) . toEqual ( 'test' )
expect ( configResult . testInt ) . toEqual ( 3 )
} )
it ( 'should parse element\'s data attribute `config` and any rest attributes. The programmatically given should excel all. Data attribute `config` should excel only Defaults' , ( ) => {
fixtureEl . innerHTML = '<div id="test" data-bs-config=\'{"testBool":false,"testInt":50,"testInt2":100}\' data-bs-test-int="8" data-bs-test-string-1="bar"></div>'
spyOnProperty ( DummyConfigClass , 'Default' , 'get' ) . and . returnValue ( {
testBool : true ,
testString : 'foo' ,
testString1 : 'foo' ,
testInt : 7 ,
testInt2 : 600
} )
const instance = new DummyConfigClass ( )
const configResult = instance . _mergeConfigObj ( {
testString1 : 'test'
} , fixtureEl . querySelector ( '#test' ) )
expect ( configResult . testBool ) . toEqual ( false )
expect ( configResult . testString ) . toEqual ( 'foo' )
expect ( configResult . testString1 ) . toEqual ( 'test' )
expect ( configResult . testInt ) . toEqual ( 8 )
expect ( configResult . testInt2 ) . toEqual ( 100 )
} )
it ( 'should omit element\'s data attribute `config` if is not an object' , ( ) => {
fixtureEl . innerHTML = '<div id="test" data-bs-config="foo" data-bs-test-int="8"></div>'
spyOnProperty ( DummyConfigClass , 'Default' , 'get' ) . and . returnValue ( {
testInt : 7 ,
testInt2 : 79
} )
const instance = new DummyConfigClass ( )
const configResult = instance . _mergeConfigObj ( { } , fixtureEl . querySelector ( '#test' ) )
expect ( configResult . testInt ) . toEqual ( 8 )
expect ( configResult . testInt2 ) . toEqual ( 79 )
} )
} )
2021-12-10 17:18:18 +01:00
describe ( 'typeCheckConfig' , ( ) => {
it ( 'should check type of the config object' , ( ) => {
spyOnProperty ( DummyConfigClass , 'DefaultType' , 'get' ) . and . returnValue ( {
toggle : 'boolean' ,
parent : '(string|element)'
} )
const config = {
toggle : true ,
parent : 777
}
const obj = new DummyConfigClass ( )
expect ( ( ) => {
obj . _typeCheckConfig ( config )
2022-11-12 09:09:36 +01:00
} ) . toThrowError ( TypeError , ` ${ obj . constructor . NAME . toUpperCase ( ) } : Option "parent" provided type "number" but expected type "(string|element)". ` )
2021-12-10 17:18:18 +01:00
} )
it ( 'should return null stringified when null is passed' , ( ) => {
spyOnProperty ( DummyConfigClass , 'DefaultType' , 'get' ) . and . returnValue ( {
toggle : 'boolean' ,
parent : '(null|element)'
} )
const obj = new DummyConfigClass ( )
const config = {
toggle : true ,
parent : null
}
obj . _typeCheckConfig ( config )
expect ( ) . nothing ( )
} )
it ( 'should return undefined stringified when undefined is passed' , ( ) => {
spyOnProperty ( DummyConfigClass , 'DefaultType' , 'get' ) . and . returnValue ( {
toggle : 'boolean' ,
parent : '(undefined|element)'
} )
const obj = new DummyConfigClass ( )
const config = {
toggle : true ,
parent : undefined
}
obj . _typeCheckConfig ( config )
expect ( ) . nothing ( )
} )
} )
} )