Skip to content

Latest commit

 

History

History
163 lines (127 loc) · 4.05 KB

directive.md

File metadata and controls

163 lines (127 loc) · 4.05 KB

Unit Testing AngularJS Directives

Testing Patterns
Example implementation of these testing patterns

####Suggested Directive Unit Test Setup

# CoffeeScript
describe 'Directive: myDir', ->
  element = scope = compile = defaultData = null
  validTemplate = '<my-dir ng-model="data"></my-dir>'

  createDirective = (data, template) ->
    # Setup scope state
    scope.data = data or defaultData

    # Create directive
    elm = compile(template or validTemplate) scope

    # Trigger watchers
    #scope.$apply()
    
    # Return
    elm

  beforeEach ->
    # Load the directive's module
    module 'myApp'

    # Reset data each time
    defaultData = 42

    # Provide any mocks needed
    module ($provide) ->
      #$provide.value 'Name', new MockName()
      # Make sure CoffeeScript doesn't return anything
      null

    # Inject in angular constructs otherwise,
    #  you would need to inject these into each test
    inject ($rootScope, $compile) ->
      scope = $rootScope.$new()
      compile = $compile
    
  describe 'when created', ->
    # Add specs

  describe 'when the model changes', ->
    # Add specs

  describe 'when destroyed', ->
    # Add specs
// JavaScript
describe('Directive: myDir', function () {
  var element, scope, compile, defaultData,
      validTemplate = '<my-dir ng-model="data"></my-dir>';

  function createDirective(data, template) {
    var elm;
    
    // Setup scope state
    scope.data = data || defaultData;

    // Create directive
    elm = compile(template || validTemplate)(scope);

    // Trigger watchers
    //scope.$apply();

    // Return
    return elm;
  }

  beforeEach(function () {

    // Load the directive's module
    module('myApp');
    
    // Reset data each time
    defaultData = 42;
    
    // Provide any mocks needed
    module(function ($provide) {
      //$provide.value('Name', new MockName());
    });
    
    // Inject in angular constructs otherwise,
    //  you would need to inject these into each test
    inject(function ($rootScope, $compile) {
      scope = $rootScope.$new();
      compile = $compile;
    });
  });

  describe('when created', function () {
    // Add specs
  });

  describe('when the model changes', function () {
    // Add specs
  });

  describe('when destroyed', function () {
    // Add specs
  });
});

My directive should:

#####throw error when ngModel attribute not defined

# CoffeeScript
it 'should throw error when ngModel attribute not defined', ->
  invalidTemplate = ->
    createDirective null, '<my-dir></my-dir>'
    # Note: older versions of Angular throw this error as: 'No controller: ngModel'
    # More recently it is: Controller 'ngModel', required by directive 'myDir', can't be found!
    expect(invalidTemplate).toThrow()
// JavaScript
it('should throw error when ngModel attribute not defined', function () {
  function invalidTemplate() {
    createDirective(null, '<my-dir></my-dir>');
  }
  // Note: older versions of Angular throw this error as: 'No controller: ngModel'
  // More recently it is: Controller 'ngModel', required by directive 'myDir', can't be found!
  expect(invalidTemplate).toThrow();
});

#####render the expected output

# CoffeeScript
it 'should render the expected output', ->
  element = createDirective()
  expect(element.text()).toBe 'this is my directive'
// JavaScript
it('should render the expected output', function () {
  element = createDirective();
  expect(element.text()).toBe('this is my directive');
});