all files / src/validators/ dependency-audit.js

100% Statements 18/18
100% Branches 11/11
100% Functions 2/2
100% Lines 18/18
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51                                                10×     12×   12×            
"use strict";
 
let semver = require("semver");
 
/**
 * Determines whether or not the package has a given dependency
 * @param  {object} packageJsonData         Valid JSON
 * @param  {string} nodeName                Name of a node in the package.json file
 * @param  {string} dependenciesToCheckFor  An array of packages to check for
 * @return {boolean}                        True if the package has a dependency. False if it is not or the node is missing.
 */
let hasDependency = function(packageJsonData, nodeName, dependenciesToCheckFor) {
  if (!packageJsonData.hasOwnProperty(nodeName)) {
    return false;
  }
 
  for (let dependencyName in packageJsonData[nodeName]) {
    if (dependenciesToCheckFor.indexOf(dependencyName) > -1) {
      return true;
    }
  }
 
  return false;
};
 
/**
 * Determines whether or not the package has a pre-release version of a given dependency
 * @param  {object} packageJsonData         Valid JSON
 * @param  {string} nodeName                Name of a node in the package.json file
 * @param  {string} dependenciesToCheckFor  An array of packages to check for
 * @return {boolean}                        True if the package has a pre-release version of a dependency. False if it is not or the node is missing.
 */
let hasDependencyPrereleaseVersion = function(packageJsonData, nodeName, dependenciesToCheckFor) {
  if (!packageJsonData.hasOwnProperty(nodeName)) {
    return false;
  }
 
  for (let dependencyName in packageJsonData[nodeName]) {
    let dependencyVersion = packageJsonData[nodeName][dependencyName];
 
    if (dependenciesToCheckFor.indexOf(dependencyName) > -1 && (dependencyVersion.includes("-beta") || dependencyVersion.includes("-rc"))) {
      return true;
    }
  }
 
  return false;
};
 
module.exports.hasDependency = hasDependency;
module.exports.hasDependencyPrereleaseVersion = hasDependencyPrereleaseVersion;