This tool analyzes the HTML, CSS, and JavaScript of a site or application for common coding issues. It warns about practices such as incomplete specification of CSS properties, invalid or incorrect doctypes, and obsolete versions of popular JavaScript libraries.
It's easiest to use modern.IE by going to the modern.IE site and entering the URL to scan there. To customize the scan, or to use the scan to process files behind a firewall, you can clone and build the files from this repo and run the scan locally.
The modern.IE local scan runs on a system behind your firewall; that system must have access to the internal web site or application that is to be scanned. Once the files have been analyzed, the analysis results are sent back to the modern.IE site to generate a complete formatted report that includes advice on remediating any issues. The report generation code and formatted pages from the modern.IE site are not included in this repo.
Since the local scan generates JSON output, you can alternatively use it as a standalone scanner or incorporate it into a project's build process by processing the JSON with a local script.
The main service for the scan is in the app.js
file; it acts as an HTTP server.
It loads the contents of the web page and calls the individual tests, located in /lib/checks/
.
Once all the checks have completed, it responds with a JSON object representing the results.
- Install node.js. You can use a pre-compiled Windows executable if desired. Version 0.10 or higher is required.
- If you want to modify the code and submit revisions, Install git. You can choose GitHub for Windows instead if you prefer. Then clone this repository. If you just want to run locally then downloading then you just need to download the latest version from here and unzip it
- Install dependencies. From the Modern.ie subdirectory, type:
npm install
- If desired, set an environment variable
PORT
to define the port the service will listen on. By default the port number is 1337. The Windows command to set the port to 8181 would be:set PORT=8181
The scanner has a CLI interface that prints directly the results for a website. You just have to run the following command to use it:
static-code-scan
- Start the scan service: From the Modern.ie subdirectory, type:
node app.js
and the service should respond with a status message containing the port number it is using. - Run a browser and go to the service's URL; assuming you are using the default port and are on the same computer, the URL would be:
http://localhost:1337/
- Follow the instructions on the page.
The project contains a set of unit tests in the /test/
directory. To run the unit tests, type grunt nodeunit
.
Once the scan completes, it produces a set of scan results in JSON format:
{
"testName" : {
"testName": "Short description of the test",
"passed" : true/false,
"data": { /* optional data describing the results found */ }
}
}
The data
property will vary depending on the test, but will generally provide further detail about any issues found.