From 5e25f3b7c946e36652764e161aec063e2d9529b8 Mon Sep 17 00:00:00 2001 From: Mike Lay Date: Thu, 15 Dec 2016 17:03:13 -0500 Subject: [PATCH] Add mixin unit tests for location-name - Add mixin unit tests for location-name --- tests/unit/mixins/location-name-test.js | 54 +++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 tests/unit/mixins/location-name-test.js diff --git a/tests/unit/mixins/location-name-test.js b/tests/unit/mixins/location-name-test.js new file mode 100644 index 0000000000..f0b8bb7b14 --- /dev/null +++ b/tests/unit/mixins/location-name-test.js @@ -0,0 +1,54 @@ +import LocationName from 'hospitalrun/mixins/location-name'; +import { moduleFor, test } from 'ember-qunit'; +import Ember from 'ember'; +import DS from 'ember-data'; + +moduleFor('mixin:location-name', 'Unit | Mixin | location-name', { + subject(attrs) { + let subject; + Ember.run(() => { + let Test = DS.Model.extend(LocationName); + this.register('model:test', Test); + subject = this.store().createRecord('test', attrs); + }); + + return subject; + }, + store() { + return this.container.lookup('service:store'); + } +}); + +test('getDisplayLocationName', function(assert) { + let locationName = this.subject(); + + assert.strictEqual( + locationName.getDisplayLocationName('Location', 'Aisle'), + 'Location : Aisle', + 'Should include both' + ); + assert.strictEqual( + locationName.getDisplayLocationName('Location'), + 'Location', + 'Should only include location' + ); + assert.strictEqual( + locationName.getDisplayLocationName('', 'Aisle'), + 'Aisle', + 'Should only include aisle location' + ); + assert.strictEqual( + locationName.getDisplayLocationName('', ''), + 'No Location', + 'Should return default "No Location" message' + ); +}); + +test('locationName', function(assert) { + let locationName = this.subject({ + location: 'Location', + aisleLocation: 'Aisle' + }); + + assert.strictEqual(locationName.get('locationName'), 'Location : Aisle'); +});