Skip to content
This repository has been archived by the owner on Nov 24, 2018. It is now read-only.

Commit

Permalink
Merge pull request #105 from saskodh/valdrMessage-memleak
Browse files Browse the repository at this point in the history
Fixed potential memory leaks
  • Loading branch information
marcelstoer committed Apr 13, 2016
2 parents 05e5872 + 9c0963b commit ec235ce
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 3 deletions.
7 changes: 5 additions & 2 deletions src/core/valdrFormGroup-directive.js
Original file line number Diff line number Diff line change
Expand Up @@ -98,12 +98,15 @@ var valdrFormGroupDirectiveDefinition =
};

this.removeMessageElement = function (ngModelController) {
messageElements[ngModelController.$name].remove();
if (messageElements[ngModelController.$name]) {
messageElements[ngModelController.$name].remove();
delete messageElements[ngModelController.$name];
}
};

}]
};
}];

angular.module('valdr')
.directive('valdrFormGroup', valdrFormGroupDirectiveDefinition);
.directive('valdrFormGroup', valdrFormGroupDirectiveDefinition);
6 changes: 5 additions & 1 deletion src/message/valdrMessage-directive.js
Original file line number Diff line number Diff line change
Expand Up @@ -141,9 +141,13 @@ angular.module('valdr')
}
}, true);

$rootScope.$on('$translateChangeSuccess', function () {
var unregisterTranslateChangeHandler = $rootScope.$on('$translateChangeSuccess', function () {
updateTranslations();
});

scope.$on('$destroy', function () {
unregisterTranslateChangeHandler();
});
}
};
}]);
15 changes: 15 additions & 0 deletions src/message/valdrMessage-directive.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -342,6 +342,21 @@ describe('valdrMessage directive with angular-translate', function () {
expect(element.find('span').html()).toBe('field: Field Name param: 3 secondParam: 4');
});

it('should unregister translate change handler on destroy to avoid potential memory leaks', function () {
// given
var element = compileTemplate();
spyOn(valdrMessage, '$translate').andReturn({ then: function () {} });
$scope.$destroy();
element.remove();

// when
$translate.use('de');
$scope.$digest();

// then
expect(valdrMessage.$translate).not.toHaveBeenCalled();
});

});

describe('valdrMessage directive with angular-translate and valdrFieldNameKeyGenerator', function () {
Expand Down

0 comments on commit ec235ce

Please sign in to comment.