Edit in Plunker
<div id="implicit" ng-controller="MyController">
  <p>Let's try the notify service, that is implicitly injected into the controller...</p>
  <input ng-init="message='test'" ng-model="message">
  <button ng-click="callNotify(message);">NOTIFY</button>
  <p>(you have to click 3 times to see an alert)</p>
</div>
angular.module('myServiceModuleDI', []).
  factory('notify', function($window) {
    var msgs = [];
    return function(msg) {
      msgs.push(msg);
      if (msgs.length == 3) {
        $window.alert(msgs.join("\n"));
        msgs = [];
      }
    };
  }).
  controller('MyController', function($scope, notify) {
    $scope.callNotify = function(msg) {
      notify(msg);
    };
  });
ge="js">
it('should test service', function() {
  expect(element(by.id('simple')).element(by.model('message')).getAttribute('value'))
      .toEqual('test');
});
^\-?\d+((\.|\,)\d+)?$/; app.directive('smartFloat', function() { return { require: 'ngModel', link: function(scope, elm, attrs, ctrl) { ctrl.$parsers.unshift(function(viewValue) { if (FLOAT_REGEXP.test(viewValue)) { ctrl.$setValidity('float', true); return parseFloat(viewValue.replace(',', '.')); } else { ctrl.$setValidity('float', false); return undefined; } }); } }; }); uot;selected" ng-transclude> </div> e.inCurr"> <option ng-repeat="c in invoice.currencies">{{c}}</option> </select> </div> <div> <b>Total:</b> <span ng-repeat="c in invoice.currencies"> {{invoice.total(c) | currency:c}} </span> <button class="btn" ng-click="invoice.pay()">Pay</button> </div> </div> "text" style="width: 400px" >', link: function(scope, element, attrs){ var input = element.children("input"), delay; input.on('keypress keyup keydown', function(event) { delay = (!delay ? $timeout(fireUrlChange, 250) : null); event.stopPropagation(); }) .val($browser.url()); $browser.url = function(url) { return url ? input.val(url) : input.val(); }; function fireUrlChange() { delay = null; $browser.urlChange(input.val()); } } }; });
var addressBar = element(by.css("#addressBar")),
     url = 'http://www.example.com/base/index.html#!/path?a=b#h';

it("should show fake browser info on load", function(){
  expect(addressBar.getAttribute('value')).toBe(url);

  expect(element(by.binding('$location.protocol')).getText()).toBe('http');
  expect(element(by.binding('$location.host')).getText()).toBe('www.example.com');
  expect(element(by.binding('$location.port')).getText()).toBe('80');
  expect(element(by.binding('$location.path')).getText()).toBe('/path');
  expect(element(by.binding('$location.search')).getText()).toBe('{"a":"b"}');
  expect(element(by.binding('$location.hash')).getText()).toBe('h');

});

it("should change $location accordingly", function(){
  var navigation = element.all(by.css("#navigation a"));

  navigation.get(0).click();

  expect(addressBar.getAttribute('value')).toBe("http://www.example.com/base/index.html#!/first?a=b");

  expect(element(by.binding('$location.protocol')).getText()).toBe('http');
  expect(element(by.binding('$location.host')).getText()).toBe('www.example.com');
  expect(element(by.binding('$location.port')).getText()).toBe('80');
  expect(element(by.binding('$location.path')).getText()).toBe('/first');
  expect(element(by.binding('$location.search')).getText()).toBe('{"a":"b"}');
  expect(element(by.binding('$location.hash')).getText()).toBe('');


  navigation.get(1).click();

  expect(addressBar.getAttribute('value')).toBe("http://www.example.com/base/index.html#!/sec/ond?flag#hash");

  expect(element(by.binding('$location.protocol')).getText()).toBe('http');
  expect(element(by.binding('$location.host')).getText()).toBe('www.example.com');
  expect(element(by.binding('$location.port')).getText()).toBe('80');
  expect(element(by.binding('$location.path')).getText()).toBe('/sec/ond');
  expect(element(by.binding('$location.search')).getText()).toBe('{"flag":true}');
  expect(element(by.binding('$location.hash')).getText()).toBe('hash');

});