微信号:gh_be6ab0a8dfb7

介绍:国内首个移动测试交流社区,最专业的 Appium 交流社区.专注于移动互联网测试和 Web 相关测试技术研究.我们的理念:Coding Share Show Cool

pipeline-安全自动化扫描测试--尝试

2018-01-12 08:00 rocl

本文重点是:实践[持续交付实践] 安全自动化扫描测试平台实现的技术细节
发现里面有一些细节需要注意,特发此帖予以记录

代码安全检查

  • 需要安装SonarQube(版本6.7,安装了Findbugs插件)

  • MySQL >=5.6,笔者安装的是MySQL 5.7版本

  • Jenkins需要安装下列插件:

    • SonarQube Scanner for Jenkins

    • Sonar Quality Gates Plugin

注意点:

  • Sonar需要配置"质量阈"

  • Sonar需要配置"web回调接口"

  • 具体script和declarative类型的pipeline代码请参见本文最后



依赖安全检查

  • Jenkins需要安装以下插件

    • Static Code Analysis Plug-ins

    • OWASP_Dependency_Check

注意点:

  • 关于搭建本地NVD镜像,这个是可以做到;如何使用本地镜像是个问题,不知道如何使用

  • Doc只提到OWASP_Dependency_Check客户端可以使用本地镜像

查出的结果如下:

安全自动化

此部分目前暂时没有实现

  • 目前有现成的security zap for pipeline插件(gradle)

  • 且需要有现成的跑web自动化的代码

附件

  • pipeline script

node {
    stage('Build') {
        echo 'Building....'
        checkout([$class: 'GitSCM', branches: [[name: '*/master']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: 'global_credentials', url: 'http://***/Test-myown.git']]])
        sh "mvn -DskipTests clean install package sonar:sonar"
        def mvnHome = tool 'M3'
        def gitDefault = tool 'gitDefault'
        def jdkver = tool 'jdk8'
        def mysonar = tool 'SonarQube Scanner 6.7'
        echo "---${mvnHome}/bin/mvn---"
        echo "---${gitDefault}---"
        echo "---${jdkver}---"
        echo "---${mysonar}---"
    }
    stage('SonarQube analysis') {
        echo "starting codeAnalyze with SonarQube......"
        withSonarQubeEnv {
          sh 'mvn -DskipTests clean install package org.sonarsource.scanner.maven:sonar-maven-plugin:3.2:sonar'
        }
    }
    stage('Quality Gate') {
        timeout(3) {
          def qg = waitForQualityGate()
            echo "---before qg:${qg.status}---"
            if (qg.status != 'OK') {
              error "未通过Sonarqube的代码质量阈检查,请及时修改!failure: ${qg.status}"
            }
            echo "---after qg:${qg.status}---"
        }
    }
    stage('Dependency Check') {
        dependencyCheckAnalyzer datadir: '', hintsFile: '', includeCsvReports: false, includeHtmlReports: true, includeJsonReports: false, includeVulnReports: true, isAutoupdateDisabled: false, outdir: '', scanpath: '', skipOnScmChange: false, skipOnUpstreamChange: false, suppressionFile: '', zipExtensions: ''
        dependencyCheckPublisher canComputeNew: false, defaultEncoding: '', failedTotalHigh: '0', healthy: '', pattern: '', unHealthy: ''
        dependencyCheckUpdateOnly()
//        dependencyTrackPublisher()--shibai失败,youchucuo有出错tishi
    }
}
  • pipeline declaractive

node {
  stage('SCM') {
    git credentialsId: 'global_credentials', url: 'http://***/Test-myown.git'
  }
  stage('SonarQube analysis') {
    echo "starting codeAnalyze with SonarQube......"
    withSonarQubeEnv {
      sh 'mvn -DskipTests clean install package org.sonarsource.scanner.maven:sonar-maven-plugin:3.2:sonar'
    }
  }

  stage('Quality Gate') {
    timeout(3) {
      def qg = waitForQualityGate()
        echo "---before qg:${qg.status}---"
        if (qg.status != 'OK') {
          error "未通过Sonarqube的代码质量阈检查,请及时修改!failure: ${qg.status}"
        }
        echo "---after qg:${qg.status}---"
    }
  }


}


 
TesterHome 更多文章 devops treafik 试用记录 基于 HttpRunner 的接口测试平台--HttpRunnerManager 用最简单的编程语言,做最实用的自动化测试 图说 2017,Hello 2018 用技术人员的思路玩微信小游戏《跳一跳》
猜您喜欢 傅盛分享:你们家空气净化器真的好用吗? 我在腾讯的面试经历 Spark vs. Pig 时间缩短8倍,计算节约45% 【搬运】实现一个有意思的TODO宏 罗一笑是真!炒作亦是真!爱心要理智!