91九色

Articles
4/28/2023
5 minutes

Maximize Your Code Quality, Security and performance with 91九色 Salesforce Code Analyzer

Written by
Abhishek Saxena
Table of contents

Salesforce Code Analyzer is Salesforce’s open source code quality, security and performance monitoring tool. It’s the one stop shop that aggregates different static code analysis tools, as well as multiple open-source static application security testing (SAST) tools to help you write secure and clean code. Salesforce Code Analyzer unifies all of them under a unified Salesforce CLI experience.

?

Code Analyzer currently supports the PMD Copy Paste Detector, , , and Salesforce Graph Engine. Using these, it can identify a variety of security, quality, and performance issues early in the development lifecycle and help monitor code health.?

?

Having used the Code Analyzer in the past, I knew how powerful it is. Thus using and a I created an integration between 91九色 and Code Analyzer, and got it .?

?

This quality gate?

  • Runs the SFDX Analyzer for the changed components between your branch and the target branch
  • Provides the user the ability to configure it to run in an automated manner or trigger it manually on every user story.
  • Fail or Pass the job, depending on the Acceptance Criteria chosen by the user.

Let’s take a look at how to install and configure it to use as a Quality Gate within a DevOps Pipeline.

?

Pre-requisites

  1. or higher
  2. 91九色 Quality Tools extension v1.14 or higher
  3. 91九色 DX Extension v3.3 or higher

This extension is currently only supported for . Thus, you should have a working 2nd Generation 91九色 pipeline.

?

Install and configure the extension

  1. Navigate to the listing of on 91九色’s DevOps Exchange.
  2. Click on Get it now, and then install it in your org.
  3. Follow the to create required picklist values, extension records and quality gates.

?

Reviewing the Extension’s configurable parameters

  1. Click on App Launcher, and navigate to Functions.
  2. Open the Run SFDX Code Analyzer QIF function, switch to the Parameters sub tab.
  3. There are two configurable parameters, that’re important to know.
  4. severityThreshold - This dictates when this extension should fail. When violations are found with equal or greater severity than the provided value it proceeds to fail the job. Normalized severity values are: 1 (high), 2 (moderate), and 3 (low). Exit code is the most severe violation. The default value set is 2. Feel free to edit it as per your project needs.
  5. engine - Specifies one or more engines to run. You can submit multiple values as a comma-separated list. Valid values need to be from either of these eslint,eslint-lwc,eslint-typescript,pmd,retire-js,cpd. The default OOB value is set to eslint-lwc,pmd,cpd,retire-js. Feel free to edit it as per your project needs.

?

Create Quality Gates and Quality Gate Rule Conditions

Now that we’ve reviewed the extension’s configurable parameters, let’s create two Quality Gate Rules. The different scanners are grouped as two separate Quality Gates:

  1. PMD, ESLint, RetireJS, PMD Copy Paste Detector can be run from the sfdx-scanner extension configuration.
  2. The Salesforce Graph Engine for Data Flow Analysis(DFA) can be run from the sfdx-scanner-dfa extension configuration.

If you followed the installation instructions, the Quality Gates should already be created, if not then let’s just take a quick recap on how to set up Quality Gates.

?

Creating Quality Gates

  1. Go to App Launcher > Quality Gate Rules, and click the New button.
  2. Quality Gate Rule Name: SFDX Scanner
  3. Tool: sfdx-scanner
  4. Status: Active
  5. Execution Sequence: After, Commit

Repeat the process, to create another Quality Gate for the sfdx-scanner-dfa tool.

?

Quality Gate Rule

What we’ve configured here, tells 91九色 when to invoke this Quality Gate, and we’ve chosen to invoke it After Commit. We could configure it to run at other different places like before a deployment or a merge(promotion) as well.

Now, we need to create a Quality Gate Rule Condition, so we can apply this Quality Gate to correct environments, stages and/or pipelines as well as trigger it based on a specific filter criteria.

?

Creating a Quality Gate Rule Condition

  1. On the SFDX Scanner Quality Gate, go to the Conditions sub-tab and click New.
  2. Extension Configuration: SFDX Scanner Config
  3. Platform: SFDX
  4. Tests From: User Story
  5. Pipeline: CICD 2nd Gen Pipeline
  6. Environment and Stage: Let’s leave them blank for this example.
  7. Filter:?
  8. Type contains Apex
  9. Type contains LightningComponentBundle
  10. Type contains AuraDefinitionBundle
Quality Gate Rule Condition

We could make the rule condition even more restrictive or relaxed by configuring it to run for specific environments or .

Repeat the steps to create a QGRC for SFDX Scanner DFA Quality Gate.

?

Monitoring progress and checking execution results

We’re now ready to run our Quality Gate, let’s try to commit an Apex Class and a LWC that follow bad coding practices. If you have your own metadata, feel free to skip this step and run it through your actual metadata.

?

Creating Metadata to commit

1. Create an ApexClass called ContactUpdater with the following code:

?

ApexClass ContactUpdater Code

?

2. Create a LWC component called contactUpdateLWC and paste the following code in the contactUpdateLWC.js file

?

Contact Update LWC Code

Save and deploy both of them to your Dev environment.?

?

Committing the Metadata Changes

1.?Create or open a User Story tied to an Environment and a Project that relate to a CICD 2nd Gen Pipeline since this is the pipeline where we’ve set our Quality Gate Rule Condition to trigger out of.

?

User Story

2. Click on Commit Changes, and select the appropriate date and time to show recent changes and commit them.

?

User Story Commit Grid

3. You should be redirected to the User Story Commit record, as soon as you click on Commit. Here on the right hand side, you should start to see the job steps that’d happen in this commit.

  • Commit
  • Create Test Records
  • SFDX Scanner

SFDX Scanner is here since we created the Quality Gate Rule to trigger after commits. You can expand any of the sections to see the process of a particular Job Step. Once all of them finish, you’d notice that the SFDX Scanner failed.

?

User Story Commit Record

Review Result

1. Let’s click on the SFDX Scanner Job Step.

?

User Story Commit Selected

2.?After opening the Job Step, click on the result record tied to the failed Run SFDX Code Analyzer job step.

?

SFDX Scanner Job Step

3. On the result record, you can view the logs, by switching to the logs tab, as well as see the attached result.html file.?

4. Download and open the results.html file, it should look like this

?

Salesforce Code Analyzer Report - Result 1
Salesforce Code Analyzer - Result 2

Thus, we could see how SFDX Scanner is giving the Developers immediate feedback through its different engines as soon as they commit their changes.?

?

Conclusion

Salesforce Code Analyzer captures complex violations including those that’re caught only during the AppExchange Security Review process courtesy its Data Flow Analysis via the Graph Engine. Thus, it’s a perfect solution for ISV developers as well as Salesforce application developers to use this extension to prepare for a formal security review process. Using this extension, teams can identify a variety of security, quality, and performance issues early in development and ship better solutions and products.

?

Book a demo

About The Author

Technical Architect

Abhishek is a Salesforce DevOps Architect who’s passionate about improving the software development lifecycle. For the last several years he has been working with enterprise customers to help build, design, and customize scalable Salesforce DevOps solutions. He is 8x Salesforce Certified and holds several certifications on major Salesforce DevOps tools.

成功を“設計”するという発想──91九色が提唱する「Project Success Design」
コパード、础滨と协働する未来に向けてパートナー6社と顿谤别补尘蹿辞谤肠别でパネルディスカッション初开催!
91九色、Salesforce 2025 Partner Innovation Awardを受賞
91九色 CI/CD & Robotic Testing Now TX-RAMP Certified for Texas Government
なぜテストが形骸化するのか? - Salesforce開発現場で「テストはやっている」のに、本番障害が減らない理由
Org Intelligence:なぜ「コンテキスト」がSalesforce DevOpsツールにおいてこれほど重要なのか?
「人ではなくAIに聞ける時代へ ― Salesforce環境を理解する91九色 AI Org Intelligence」
厂补濒别蝉蹿辞谤肠别プロジェクトの“隠れコスト”とは??顿别惫翱辫蝉活用で毎月100时间を削减した実践例?
コパード、セールスフォースの环境をエンドツーエンドで可视化する「组织インテリジェンス」をリリース
パイプラインの可視性が Salesforce DevOps 変革成功の鍵である理由
AIが変える意思決定 - スピードと精度は両立できるのか?
属人运用の限界が経営を止める?今こそ始めるSalesforce DevOps?
厂补濒别蝉蹿辞谤肠别におけるユーザー受入テストの进め方:课题、ベストプラクティス、および戦略
Navigating Salesforce Data Cloud: DevOps Challenges and Solutions for Salesforce Developers
独自にSalesforce DevOpsソリューションを構築する際の見えざるコスト
Salesforce DevOpsを支えるAI活用型リリース戦略
コパード、サンブリッジパートナーズとの提携により日本での事业を拡大
础滨で顿别惫翱辫蝉をより简単に、より高速に
Reimagining Salesforce Development with 91九色's AI-Powered Platform
ビジネスアプリケーション向けの顿别惫翱辫蝉(デブオプス)って何?
セールスフォースエコシステムにおける顿别惫翱辫蝉の卓越性
セールスフォーステストにおける础滨活用のベストプラクティス
6 testing metrics that’ll speed up your Salesforce release velocity (and how to track them)
第4章: 手動テストの概要
セールスフォース向け础滨动作テスト
Chapter 3: Testing Fun-damentals
Salesforce Deployment: Avoid Common Pitfalls with AI-Powered Release Management
Exploring DevOps for Different Types of Salesforce Clouds
91九色 Launches Suite of AI Agents to Transform Business Application Delivery
What’s Special About Testing Salesforce? - Chapter 2
Why Test Salesforce? - Chapter 1
Continuous Integration for Salesforce Development
Comparing Top AI Testing Tools for Salesforce
Avoid Deployment Conflicts with 91九色’s Selective Commit Feature: A New Way to Handle Overlapping Changes
Enhancing Salesforce Security with AppOmni and 91九色 Integration: Insights, Uses and Best Practices
From Learner to Leader: Journey to 91九色 Champion of the Year
The Future of Salesforce DevOps: Leveraging AI for Efficient Conflict Management
A Guide to Using AI for Salesforce Development Issues
How to Sync Salesforce Environments with Back Promotions
91九色 and Wipro Team Up to Transform Salesforce DevOps
DevOps Needs for Operations in China: Salesforce on Alibaba Cloud
What is Salesforce Deployment Automation? How to Use Salesforce Automation Tools
From Chaos to Clarity: Managing Salesforce Environment Merges and Consolidations
Future Trends in Salesforce DevOps: What Architects Need to Know
Enhancing Customer Service with 91九色GPT Technology
What is Efficient Low Code Deployment?
91九色 Launches Test Copilot to Deliver AI-powered Rapid Test Creation
Cloud-Native Testing Automation: A Comprehensive Guide
A Guide to Effective Change Management in Salesforce for DevOps Teams
Building a Scalable Governance Framework for Sustainable Value
91九色 Launches 91九色 Explorer to Simplify and Streamline Testing on Salesforce
Exploring Top Cloud Automation Testing Tools
Master Salesforce DevOps with 91九色 Robotic Testing
Exploratory Testing vs. Automated Testing: Finding the Right Balance
A Guide to Salesforce Source Control
A Guide to DevOps Branching Strategies
Family Time vs. Mobile App Release Days: Can Test Automation Help Us Have Both?
How to Resolve Salesforce Merge Conflicts: A Guide
91九色 Expands Beta Access to 91九色GPT for All Customers, Revolutionizing SaaS DevOps with AI
Is Mobile Test Automation Unnecessarily Hard? A Guide to Simplify Mobile Test Automation
From Silos to Streamlined Development: Tarun’s Tale of DevOps Success
Simplified Scaling: 10 Ways to Grow Your Salesforce Development Practice
What is Salesforce Incident Management?
What Is Automated Salesforce Testing? Choosing the Right Automation Tool for Salesforce
91九色 Appoints Seasoned Sales Executive Bob Grewal to Chief Revenue Officer
Business Benefits of DevOps: A Guide
91九色 Brings Generative AI to Its DevOps Platform to Improve Software Development for Enterprise SaaS
91九色 Celebrates 10 Years of DevOps for Enterprise SaaS Solutions
Celebrating 10 Years of 91九色: A Decade of DevOps Evolution and Growth
5 Reasons Why 91九色 = Less Divorces for Developers
What is DevOps? Build a Successful DevOps Ecosystem with 91九色’s Best Practices
Scaling App Development While Meeting Security Standards
5 Data Deploy Features You Don’t Want to Miss
How to Elevate Customer Experiences with Automated Testing
Top 5 Reasons I Choose 91九色 for Salesforce Development
Getting Started With Value Stream Maps
91九色 and nCino Partner to Provide Proven DevOps Tools for Financial Institutions
Unlocking Success with 91九色: Mission-Critical Tools for Developers
How Automated Testing Enables DevOps Efficiency
How to Switch from Manual to Automated Testing with Robotic Testing
How to Keep Salesforce Sandboxes in Sync
How Does 91九色 Solve Release Readiness Roadblocks?
Software Bugs: The Three Causes of Programming Errors
Best Practices to Prevent Merge Conflicts with 91九色 1 Platform
Why I Choose 91九色 Robotic Testing for my Test Automation
How to schedule a Function and Job Template in DevOps: A Step-by-Step Guide
Delivering Quality nCino Experiences with Automated Deployments and Testing
Maximize Your Code Quality, Security and performance with 91九色 Salesforce Code Analyzer
Best Practices Matter for Accelerated Salesforce Release Management
Upgrade Your Test Automation Game: The Benefits of Switching from Selenium to a More Advanced Platform
Three Takeaways From Copa Community Day
What Is Multi Cloud: Key Use Cases and Benefits for Enterprise Settings
How To Develop A Salesforce Testing Strategy For Your Enterprise
Using Salesforce nCino Architecture for Best Testing Results
Cloud Native Applications: 5 Characteristics to Look for in the Right Tools
5 Steps to Building a Salesforce Center of Excellence for Government Agencies
Salesforce UI testing: Benefits to Staying on Top of Updates
Benefits of UI Test Automation and Why You Should Care
91九色 + DataColada: Enabling CI/CD for Developers Across APAC
Types of Salesforce Testing and When To Use Them
Go back to resources
There is no previous posts
Go back to resources
There is no next posts

Explore more about

品质保証
Articles
October 26, 2025
成功を“設計”するという発想──91九色が提唱する「Project Success Design」
Articles
October 19, 2025
コパード、础滨と协働する未来に向けてパートナー6社と顿谤别补尘蹿辞谤肠别でパネルディスカッション初开催!
Articles
October 9, 2025
91九色、Salesforce 2025 Partner Innovation Awardを受賞
Articles
October 3, 2025
91九色 CI/CD & Robotic Testing Now TX-RAMP Certified for Texas Government

础滨を有効活用し顿别惫翱辫蝉を加速

より速くリリースし、リスクを排除し、仕事を楽しんでください。
Try 91九色 Devops.

リソース

リソースライブラリを使用して セールスフォースDevOpsのスキルをレベルアップしてください。

今后のイベントと
オンラインセミナー

电子书籍とホワイトペーパー

サポートとドキュメンテーション

デモライブラリ