On this page: Target audience: Users of the extension providing AngularJS support for Web applications. |
Summary: This document provides basic information about the extension providing AngularJS support for Web applications. |
This extension provides support for AngularJS.
If your Web application contains AngularJS source code and you want to view these object types and their links with other objects, then you should install this extension:
Regarding Front-End to Back-End connections, we do support the following cross-technology stacks (click to enlarge):
![]() | ![]() |
AngularJS Front-End connected JEE Back-End | AngularJS Front-End connected Node.js Back-End |
The following table displays the supported versions matrix:
Version | Transaction Support | Rules Support | Type of Support |
---|---|---|---|
1.0 | Fullstack use case support | ||
1.2 | Fullstack use case support | ||
1.3 | Fullstack use case support | ||
1.4 | Fullstack use case support | ||
1.5 | Fullstack use case support | ||
1.6 | Fullstack use case support |
Function Points (transactions) | Quality and Sizing |
---|---|
CAST AIP has provided support for analyzing JavaScript via its J2EE and .NET analyzers (provided out of box in CAST AIP) for some time now. The HTML5/JavaScript extension (on which the AngularJS extension depends) also provides support for JavaScript but with a focus on web applications. CAST highly recommends that you use this extension if your Application contains JavaScript and more specifically if you want to analyze a web application, however you should take note of the following:
CAST AIP release | Supported |
---|---|
8.2.x | |
8.1.x | |
8.0.x | |
7.3.4 and all higher 7.3.x releases |
This extension is compatible with the following DBMS servers:
CAST AIP release | CSS2 | Oracle | Microsoft |
---|---|---|---|
All supported releases |
An installation of any compatible release of CAST AIP (see table above) |
Some CAST extensions require the presence of other CAST extensions in order to function correctly. The AngularJS extension requires that the following other CAST extensions are also installed:
Note that when using the CAST Extension Downloader to download the extension and the Manage Extensions interface in CAST Server Manager to install the extension, any dependent extensions are automatically downloaded and installed for you. You do not need to do anything. |
Please see:
The latest release status of this extension can be seen when downloading it from the CAST Extend server. |
Please see: AngularJS - Packaging, delivering and analyzing your source code
Once the analysis/snapshot generation has completed, you can view the results in the normal manner (for example via CAST Enlighten):
E.g. : AngularJS Front-end connected to Node.js Back-end
E.g. : AngularJS Front-end connected to JEE/Spring MVC Back-end
The following specific objects are displayed in CAST Enlighten:
Icon | Description |
---|---|
![]() | AngularJS Application |
![]() | AngularJS Controller |
![]() | AngularJS Directive |
![]() | AngularJS Directive Controller |
![]() | AngularJS Directive Link Function |
![]() | AngularJS Factory |
![]() | AngularJS Model function |
![]() | AngularJS Model variable |
![]() | AngularJS Service |
![]() | AngularJS Get Resource Service |
![]() | AngularJS Post Resource Service |
![]() | AngularJS Put Resource Service |
![]() | AngularJS Delete Resource Service |
![]() | AngularJS Get Http Service |
![]() | AngularJS Post Http Service |
![]() | AngularJS Put Http Service |
![]() | AngularJS Delete Http Service |
![]() | AngularJS Watch function |
If your application is supposed to be communicating with services, ensure you have GET, POST, PUT and DELETE Service objects created after the analysis. |
You can find a full list of rules delivered with this extension here: https://technologies.castsoftware.com/?rlH=extensions/com.castsoftware.angularjs/1.2.0-funcrel.json
AngularJS Service objects are not considered by CAST AIP as being part of any transaction (they are considered as technical function points). Instead, the AngularJS Service's functions are considered to be part of the transaction. Therefore when looking at the results of an AngularJS analysis, links to the AngularJS Service's functions should be checked to ensure that the expected transactions exist. Transactions within AngularJS are ALWAYS from functions or methods to functions or methods (objects which are executable).
In this section we list the most significant functional limitations that may affect the analysis of applications using AngularJS:
xxx.service('ContentService', ['$rootScope', '$window', '$resource', '$q', '$log', 'ManageContentURIs', attContent.content]); attContent.content.prototype.retrieveContent = function(criteria, useStubs) { var useStub = useStubs?useStubs:false; var deferred = this.q.defer(), |