-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #13 from bem-sdk/qfox.feat-create
BemCell.create method
- Loading branch information
Showing
4 changed files
with
148 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
const test = require('ava'); | ||
|
||
const BemEntityName = require('@bem/entity-name'); | ||
|
||
const BemCell = require('../index'); | ||
|
||
test('should return object as is if it`s a BemCell', t => { | ||
const cell = new BemCell({ entity: new BemEntityName({ block: 'b' }) }); | ||
|
||
t.is(BemCell.create(cell), cell); | ||
}); | ||
|
||
test('should return cell with passed entityName', t => { | ||
const entity = new BemEntityName({ block: 'b' }); | ||
|
||
t.is(BemCell.create(entity).entity, entity); | ||
}); | ||
|
||
test('should create BemCell for block from obj', t => { | ||
const cell = BemCell.create({ block: 'b' }); | ||
|
||
t.pass(cell instanceof BemCell, 'Should be an instance of BemCell'); | ||
t.is(cell.entity.block, 'b', 'Should create entity with BemEntityName.create'); | ||
}); | ||
|
||
test('should create cell for elem from obj', t => { | ||
const cell = BemCell.create({ block: 'b', elem: 'e' }); | ||
|
||
t.deepEqual(cell.entity.valueOf(), { block: 'b', elem: 'e' }); | ||
}); | ||
|
||
test('should create cell with tech', t => { | ||
const cell = BemCell.create({ block: 'block', tech: 'css' }); | ||
|
||
t.is(cell.tech, 'css'); | ||
}); | ||
|
||
test('should create cell with layer', t => { | ||
const cell = BemCell.create({ block: 'block', layer: 'desktop' }); | ||
|
||
t.is(cell.layer, 'desktop'); | ||
}); | ||
|
||
test('should create cell with layer', t => { | ||
const cell = BemCell.create({ block: 'block', tech: 'css', layer: 'desktop' }); | ||
|
||
t.is(cell.tech, 'css'); | ||
t.is(cell.layer, 'desktop'); | ||
}); | ||
|
||
test('should create BemCell for block from obj', t => { | ||
const cell = BemCell.create({ block: 'b', elem: 'e', mod: 'm', val: 'v', tech: 't', layer: 'l' }); | ||
|
||
t.deepEqual(cell.valueOf(), { | ||
entity: { block: 'b', elem: 'e', mod: { name: 'm', val: 'v' } }, | ||
tech: 't', | ||
layer: 'l' | ||
}); | ||
}); | ||
|
||
test('should create BemCell for entity with tech and layer from obj', t => { | ||
const cell = BemCell.create({ entity: { block: 'b', mod: 'm', val: 'v' }, tech: 't', layer: 'l' }); | ||
|
||
t.deepEqual(cell.valueOf(), { | ||
entity: { block: 'b', mod: { name: 'm', val: 'v' } }, | ||
tech: 't', | ||
layer: 'l' | ||
}); | ||
}); |