angular/angular.js

View on GitHub
benchmarks/ng-class-bp/app.js

Summary

Maintainability
B
6 hrs
Test Coverage
'use strict';

var app = angular.module('ngClassBenchmark', []);

app.controller('DataController', function DataController($scope) {

  this.init = function() {
    this.numberOfTodos = 1000;
    this.implementation = 'tableOptimized';
    this.completedPeriodicity = 3;
    this.importantPeriodicity = 13;
    this.urgentPeriodicity = 29;

    this.createTodos(100);
    this.setTodosValuesWithSeed(0);
  };

  this.clearTodos = function() {
    this.todos = null;
  };

  this.createTodos = function(count) {
    var i;
    this.todos = [];
    for (i = 0; i < count; i++) {
      this.todos.push({
        id: i + 1,
        completed: false,
        important: false,
        urgent: false
      });
    }
  };

  this.setTodosValuesWithSeed = function(offset) {
    var i, todo;
    for (i = 0; i < this.todos.length; i++) {
      todo = this.todos[i];
      todo.completed = 0 === (i + offset) % this.completedPeriodicity;
      todo.important = 0 === (i + offset) % this.importantPeriodicity;
      todo.urgent = 0 === (i + offset) % this.urgentPeriodicity;
    }
  };

  this.init();


  benchmarkSteps.push({
    name: 'setup',
    fn: function() {
      $scope.$apply();
      this.clearTodos();
      this.createTodos(this.numberOfTodos);
    }.bind(this)
  });

  benchmarkSteps.push({
    name: 'create',
    fn: function() {
      // initialize data for first time that will construct the DOM
      this.setTodosValuesWithSeed(0);
      $scope.$apply();
    }.bind(this)
  });

  benchmarkSteps.push({
    name: '$apply',
    fn: function() {
      $scope.$apply();
    }
  });

  benchmarkSteps.push({
    name: 'update',
    fn: function() {
      // move everything but completed
      this.setTodosValuesWithSeed(3);
      $scope.$apply();
    }.bind(this)
  });

  benchmarkSteps.push({
    name: 'unclass',
    fn: function() {
      // remove all classes
      this.setTodosValuesWithSeed(NaN);
      $scope.$apply();
    }.bind(this)
  });

  benchmarkSteps.push({
    name: 'class',
    fn: function() {
      // add all classes as the initial state
      this.setTodosValuesWithSeed(0);
      $scope.$apply();
    }.bind(this)
  });

  benchmarkSteps.push({
    name: 'destroy',
    fn: function() {
      this.clearTodos();
      $scope.$apply();
    }.bind(this)
  });

});