Dynamic Analysis Group
Dynamic Analysis
The Dynamic Analysis group at GitLab is charged with developing solutions which perform Dynamic Analysis Software Testing (DAST) and Fuzzing. Our work is a mix of open and closed source code.
Mission
To support the success of GitLab by developing highly usable, hiqh quality tools for customers to build more secure software. The Dynamic Analysis group at GitLab is charged with developing solutions which perform API Security Testing, Dynamic Analysis Software Testing (DAST) and Fuzzing.
Top Priorities (FY25)
Theme: Increase adoption
-
Unify DAST offerings - Reduce confusion by removing proxy-based DAST and maturing browser-based DAST by adding active checks and improving performance
-
API Discovery - API discovery will analyze applications to produce an OpenAPI document describing the web APIs expected behavior. This schema document is then used by API Security testing (formerly called DAST API) to perform security scans. Automating this will close the gap for customers whose applications include web APIs that haven’t been documented and aren’t being tested today.
-
API Security Checks refresh - Comprehensively review and update API Security Testing checks (rules). By ensuring we address both the OWASP API Security Top 10:2023 and the OWASP Top 10:2021 (web applications), our customers will be confident in our ability to detect critical risks.
-
DAST Performance - Deduplicate scanning similar pages to reduce DAST scan times without reducing security coverage. Long scan times are a major barrier that discourages customers from incorporating DAST scans into DevSecOps processes.
Customer outcomes We are Driving
The Dynamic Analysis team builds features for our API Security, DAST, and Fuzzing categories. These features enable our Ultimate customers to incorporate security testing earlier in the development lifecycle for their web applications and APIs. By identifying vulnerabilities earlier in the SDLC, we enable customers to more efficiently reduce the security risks in their web apps and APIs.
Our features identify vulnerabilities in different ways than GitLab’s other security analyzers do, and each tool should be used in tandem with other security analyzers such as SAST, SCA (dependency scanning), and secret detection to provide full coverage.
API Security, DAST, and Fuzzing are Ultimate features. Increasing adoption of these features helps improve customer retention, and helps drive revenue for GitLab Ultimate.
Important DAST Repositories
Repo | Purpose |
---|---|
DAST | The DAST Analyzer which is deployed as a docker image. |
Browserker | Private - GitLab’s DAST browser-based analyzer. |
DAST CWE Checks | Private - DAST browser-based analyzer vulnerability definitions. |
DAST Chromium | Private - DAST browser-based analyzer dependencies, such as the Chromium browser. |
Important Fuzzing repositories
Repo | Purpose |
---|---|
API Security | Private - The API Security tool performs API Fuzzing and API DAST scans. |
GitLab Protocol Fuzzer (CE) | GitLab’s Protocol Fuzzer (Community Edition), previously Peach Protocol Fuzzer. |
GitLab Protocol Fuzzer (EE) | Private - GitLab’s Protocol Fuzzer (Enterprise Edition), previously Peach Protocol Fuzzer, includes licensed components. |
API Fuzzing E2E Tests | Private - API End to End Tests. |
GitLab Cov Fuzz | Private - GitLab’s coverage fuzzing orchestration that integrates fuzzing engines/results with GitLab CI and GitLab Security Dashboard. |
HAR Recorder | A utility to record HAR files based on web traffic. |
Open Source Fuzzers
Repo | Purpose |
---|---|
JSfuzz | Javascript Fuzzer. |
Pythonfuzz | Python Fuzzer. |
Javafuzz | Java Fuzzer. |
Coverage Fuzzing Examples | Coverage fuzzing examples in 7+ languages/Fuzzers. |
How to Contact Us
- Slack channel: #g_ast-dynamic-analysis, #f_ast-api-security, #f_ast-fuzz-testing
- Slack alias: @secure_dynamic_analysis_be
- Google groups: dynamic-analysis-be@gitlab.com
- GitLab mention: @gitlab-org/secure/dynamic-analysis-be
Support Requests
The Dynamic Analysis engineering team provides support to GitLab Support Engineers following the process outlined in the Sec Section support project.
Other Contact
The DAST team also monitors #s_application-security-testing and #sec-section. Both these channels are for wider AST topics, however are a good place to start if you are not sure which group in AST to contact.
How We Work
timeline title Annual Kanban Ceremonies section Q1 <br> OKR Development Sync M1 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M2 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M3 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync section Q2 <br> OKR Development Sync M4 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M5 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M6 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync section Q3 <br> OKR Development Sync M7 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M8 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M9 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync section Q4 <br> OKR Development Sync M10 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M11 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync M12 <br> Milestone Planning Sync : W1 <br> Weekly Team Sync : W2 <br> Weekly Team Sync : W3 <br> Weekly Team Sync : W4 <br> Weekly Team Sync
The Dynamic Analysis group works according to Kanban principles, with the addition of ceremonies quarterly for OKR development, monthly for release planning, and weekly for syncing on epic and issue reacting, triaging, refinement, impediment resolution. By having the team operate and think at each of these cadences, it can effectively set high-level hierarchical goals, ensure product priorities are planned, and prevent epics and issue work from stalling or falling through the cracks.
Hallway Monitor Bot
For all quarterly, monhtly, and weekly Kanban ceremonies, the Hallway Monitor Bot is our guiding star, allowing the team to pontificate and plan at all cadences, ensuring we get ahead of future work. The bot will schedule quarterly OKR review meetings, monthly release planning and retro meetings, and will update or weekly sync guide with the latest team member assigned to the temporary reaction rotation role. We should strive to automate as many of our business process as possible, and the Hallway Monitor Bot Configuration and Templates allow for many of your automation ideas. Please help contribute to the bot to help keep our team as efficient as possible.
Quarterly OKR Development
timeline section Q1 <br> OKR Development Sync section Q2 <br> OKR Development Sync section Q3 <br> OKR Development Sync section Q4 <br> OKR Development Sync
Four weeks before the end of a fiscal quarter, our bot will automatically create an OKR planning issue for the group and schedule a calendar event.
The group will get together two weeks before the next quarter begins to create and review all OKRs for which the team will ultimately be responsible. This includes reviewing all ancestor OKRs for the stage and up, creating or updating any new or existing OKRs with additional details, and assigning DRIs to each OKR to assist with health updates.
Important Links
- List of Team Objectives & Key Results
- List of Stage Objectives & Key Results (Coming Soon)
- List of CEO Objectives & Key Results (Coming Soon)
Quarterly Outputs
- Polished OKRs for the group with assigned DRIs
- Links to any associated epics or issues
Milestone Release Planning
timeline section M1 <br> Milestone Planning Sync section M2 <br> Milestone Planning Sync section M3 <br> Milestone Planning Sync section M4 <br> Milestone Planning Sync section M5 <br> Milestone Planning Sync section M6 <br> Milestone Planning Sync section M7 <br> Milestone Planning Sync section M8 <br> Milestone Planning Sync section M9 <br> Milestone Planning Sync section M10 <br> Milestone Planning Sync section M11 <br> Milestone Planning Sync section M12 <br> Milestone Planning Sync
Two weeks before a release milestone is kicked off, our Hallway Monitor Bot will automatically create a monthly release planning issue for the group and schedule a calendar event. This issue serves as the Kanban backlog for the milestone, aligning PM priorities with the EM and all of the ICs. The issue is divided into three sections:
- Work to Release - all work that we are committing to release during this milestone
- Work to Start/Continue - new work being brought in or existing work rolling over from a previous milestone
- Work to Blueprint - work that needs high-level planning and breakdown this milestone before development work in the next milestone
On the date of a release milestone kick-off, we will review the list of Dynamic Analysis Group direction priorities with product and ensure all of the priorities for the current milestone are reflected in the monthly release planning issue in the “Work to Release” and “Work to Start/Continue” sections. Medium to large sized bodies of work identified for the next milestone by our PM should be added to the “Work to Blueprint” section for high-level blueprinting and breakdown of the work for pick-up in the next milestone.
Product sets all of our high-level priorities, and in addition to the above, another output from this kick-off meeting can be an MR update to direction page with an updated mapping of each priority to a group issue/epic and/or targeted milestone. This process allows for the EM and ICs to give direct feedback to our PM for how we’d like to organize the work and which milestone we think we can get to future roadmap items.
All product priority-based issues will exist alongside our comprehensive list of all Dynamic Analysis Group issues. All product priority-based epics will exist alongside our comprehensive list of all Dynamic Analysis Group epics.
To complete this mapping, product priority-based issues or epics should be created in gitlab-org/gitlab
or gitlab-org
(respectively) with the same title of the priority and the following labels. The type::feature
label is what distinguishes a product priority from other group epic work.
/label ~"section::sec"
/label ~"devops::application security testing"
/label ~"group::dynamic analysis"
/label ~"type::feature"
Milestone Retrospectives
After the completion of any milestone, the planning issue for that milestone is used to capture team retros in the comments. Before the next milestone planning kickoff meeting, each team member should answer the following questions in a comment on that issue:
- 👍 what went well this release?
- 👎 what didn’t go well this release?
- 📈 what can we improve going forward?
- 🌟 what praise do you have for the group?
Important Links
- Dynamic Analysis Group Direction Priorities
- List of all Dynamic Analysis Milestone Planning Issues & Retros
Milestone Outputs
- MR to update the group direction with all priorities and targeted releases
- Links to polished epics or issues for each product priority
- Flush out as many child epics and issues tagged to milestones as possible (or a single blueprinting issue)
- Links to polished epics or issues for each product priority
- Team retrospective comments will be reviewed inside of the previous milestone’s planning issue
Weekly Huddles & Reaction Coordination
Monday’s Developers Huddle
Every Monday, a calendar event with an attached agenda exists for a synchronous development group meeting. This meeting is engineering focused and includes all engineers on the team and the engineering manager. The purpose of this meeting is to discuss development efforts, strategies, tooling, active MRs, and to guide each other’s coding and review efforts. Additionally, the team will discuss all of the active blueprinting items defined in the current milestone planning issue, using this time to discuss implementation plans, spikes, and architectural decisions; all in hope of establishing epics and issues for work in the next milestone.
Tuesday’s General Huddle
Every Tuesday, a calendar event with an attached agenda exists for a synchronous general group meeting. This meeting is product focused and includes all engineers on the team, the engineering manager, and the product manager. The purpose of this meeting is to discuss product efforts, timelines, and serves as a direct two-way feedback mechanism between product and the engineering team. We will review the current milestone planning issue as our transient backlog and ensure that we are staying focused on these priorities. The group will also rotate to a new Reaction Coordinator, discuss any unresolved and significant/product impediments blocking the team, and host general discussions valuable to a synchronous team meetup with our product manager.
Wednesday’s Support Huddle
Every Wednesday, a calendar event with an attached agenda exists for a synchronous support group meeting. This meeting is support focused and includes our primary support engineer, the engineering manager, our product manager, and, as optional members, all engineers on the team. The purpose of this meeting is to discuss active support cases and ensure they are added to our delivery board, improve our support runbooks, review live debugging and log reviews of recent support cases, spread support resolution knowledge, and suggest product improvements that will make resolving these support issues easier for the customer, GitLab support, and the team.
Reaction Coordinator
DAST uses a reaction coordinator rotation to give each team member in the group the opportunity to ensure all internally and externally generated epics and issues are triaged or resolved as efficienctly as possible.
Engineers rotate through the position to give everyone equal opportunity both in the role and away from the role. The weekly sync agenda document will contain the currently assigned reaction coordinator. The reaction rotation aims to produce better group workflow, support and quality, and community outcomes by encouraging knowledge sharing, reducing dependencies on individuals in knowledge silos, and clarifying who is responsible for responding to any external requests.
Due to the unpredictable nature of all of the following triage items, it is hard to determine the impact of reaction coordinator rotation on an engineer’s typical throughput, but a significant decrease is to be expected for the betterment of all of these stakeholders.
The reaction coordinator of the week is responsible for triaging:
Dynamic Analysis delivery board columns near their WIP limits
Dynamic Analysis delivery board
- Issues that need to be refined with the
~workflow::planning breakdown
label - Issues that need to be broken down in any status
- All other columns with too many issues
Blocked epics or issues anywhere in the workflow
External support issues
- Triage and respond to customer support requests via support request for help issues. As an outcome of triage, create new issues and communicate with the product team to help assign priority.
- Triage and respond to customer support requests via Slack. Encourage customers/support teams to create support tickets because of Slack’s short retention history.
- Ensure high-quality support request responses. Reach out to other engineers, teams, or people with knowledge to ensure customers get the best possible answers.
External Security & Quality Issues
- Ensure security issues (for FedRAMP compliance or platform security) are created or updated, either manually or through automation. Follow up with creation of Deviation Requests if necessary.
- See the AST sub-department vulnerability management process.
Community contributions
- Act as an MR Coach for newly created community contributions.
Out of Scope of the Role
The reaction rotation engineer should not:
- Directly fix issues as a result of customer support triage. The product team must prioritize any issue prior to an engineer picking it up.
- Exclusively work on community contributions, security issues, or bug fixes. These are the purview of the entire team.
- Take the time as slack time. Slack time is important in everyone’s role and is captured as a constant when measuring team throughput to predict release dates.
Weekly Outputs
- Assign a new Reaction Coordinator
- Discuss any unresolved and significant impediments
- General team discussions
Daily Look Left & Right Before Dev
On any day, each team member should look left and right on our Dynamic Analysis delivery board before they start developing any new work from the workflow::ready for development
column, helping to move one issue forward from both directions (2 total). The team follows the workflow states and activities articulated in GitLab’s Product Development Flow. Looking left involves grabbing an issue from either the workflow::refinement
or the workflow::ready for development
columns, whichever has more items, and completing it. Looking right involves grabbing an issue from either the workflow::in review
or the workflow::verification
columns, whichever has more items, and completing it. After both issues have been moved to a new column, the team member can start ready work from the workflow::ready for development
.
The Look Left & Right Before Dev
strategy ensures that work items aren’t getting stuck on our board, that every team member gets a chance to plan, breakdown, and refine issues, and that code reviews and staging/production vefification activities are spread equally across the team. If there is no work to the left, new work can be brought in from our milestone backlog, as defined in our current Milestone Release Planning issue. New work may also be added to the first two columns at any time from sales and support request for help issue, high-priority bugs, and security-related issues.
Blueprinting & Design Docs
When there are too few or no work items in the workflow::refinement
or the workflow::ready for development
columns, check the current Milestone Release Planning issue for “Work to Blueprint” issues. Assign yourself as a DRI, and assist in scheduling the necessary meetings with the team to review and help blueprint this work for the next milestone. Attempt to create as many child epics and issues as placeholders for eventual planning, breakdown, and refinement. This is a great time for the team to discuss high-level architectural directions, implementation plans, and needs for accomplishing these priorities throughout the next month. All blueprint issues created should receive the following milestone and labels:
/milestone {from mapping}
/label ~"section::sec"
/label ~"devops::application security testing"
/label ~"group::dynamic analysis"
/label `~workflow::planning breakdown`
If a bluepriting effort is beyond the scope of the Dyanmic Analysis group, affecting multiple teams, consider adding it as a design document using this process. A list of all architecture design documents at GitLab can be found here.
Issue breakdown
Team members are empowered to create new issues, attach them to relevant epics, and collaborate with product management to determine if they are included in current scope.
Breakdown principles
Issues are broken down according to the INVEST mnemonic.
- Independent, the issue should have minimal to no dependencies so it can be played in isolation of other issues.
- Negotiable, the issue should be structured such that the PM can prioritize or deprioritize it with minimal effect on the overall feature.
- Valuable, the issue should provide value when released to production.
- Estimable, the issue should make clear what is in scope and out of scope so that engineers can provide an estimate.
- Small, the issue must fit inside one milestone, ideally, design to delivery should take less than two weeks.
- Testable, the issue must be able to be tested. If it can’t be tested, it can’t be guaranteed to work in future.
Vertically Split
Issues should be split vertically rather than horizontally. Splitting vertically means the whole system will do something noticeably different; splitting horizontally results in trying to realize the fullest possible change in an individual component.
For example, imagine there is an epic to a CRUD feature to a site. Issues could be split up and played in the following order:
- Read. This is independent, negotiable, estimable, small and testable. It is also valuable because in production an engineer could manually create the data to be read by users.
- Create. This is independent, estimable, and small. It is testable because the Read functionality has already been built. It is valuable because engineers don’t need to manually create data anymore, and it is negotiable because a PM may decide that engineers manually creating data is good enough.
- Delete. Same as above, and it is valuable because engineers wouldn’t need to manually delete records in production.
- Update. Same as above, and it is often deprioritized by PMs because Create and Delete is often good enough.
Repeated Tasks
There are several maintenance tasks that need to be completed each milestone. Each iteration, an issue is opened and assigned to an engineer on a rotating basis. Those rotating tasks are:
- Review upstream changes, and open an issue to upgrade DAST if the upstream changes provide important improvements
- Review the security dashboard for DAST and address all critical and high issues. Review the dashboards for upstream projects, ZAP and ZAP Extensions
DAST Technologies
The DAST analyzer we build relies heavily on OWASP’s ZAP open source software and ZAP Extensions. This means the accuracy and quality of the DAST analyzer is impacted by the quality of the underlying OSS.
We monitor the underlying tools for changes and for vulnerabilities.
ZAProxy and ZAP Extensions do not have significant test coverage and therefore changes in those tools could impact DAST in unexpected ways. Since our expectation is that customers run DAST in a CI environment and stability and security is of utmost importance, we do not necessarily ship the latest ZAP build. We actively review the ZAP changelog and evaluate whether new updates deliver value to our customers and their use cases. We may ship a pre-release build of ZAP or a versioned build if we determine it contains valuable updates for customers and it passes our CI pipelines.
An assigned backend engineer reviews upstream updates at least monthly to identify new bug fixes or features. Those changes are presented to the Product Manager for prioritization into DAST.
New DAST Technologies
The DAST analyzer is migrating towards using exclusively a browser-based DAST tool that is being built by GitLab. The tool has internally been referrred to as Browserker. Browser based DAST was released as GA in 15.7. The browser-based DAST is being delivered iteratively, with each new iteration taking over some parts of analysis previously done by ZAP, with the eventual goal of deprecating ZAP completely.
Fuzzing Technologies
- The API Security product is built using mostly C# with some small amounts of Python. Our engineers use Windows VMs for development.
- The coverage guided fuzzing team works primarily in Go, but is also responsible for maintaining the open source fuzzers in JSFuzz, Pythonfuzz, and Javafuzz. The team also maintains the fuzzing examples in which we aim to cover all major programming languages.
Our Approach to Fuzzing
- Fuzzing has one of the largest adoption hurdles of all the AST products. Coverage fuzzing requires customers to write test harnesses, compile applications with special settings and generates highly technical output.
Web API Fuzzing requires generating files that allow the Web API fuzzing tool to know what parts of the application to fuzz.
Our goals is to simplify and reduce as many of the steps that a customer needs to do to get started. We want to focus our efforts on creating samples, defaults, and intelligence that will simplify fuzzing onboarding.
Community Contributions
The Dynamic Analysis welcomes community contributions. Community Contributors– please make sure to add the label “group::dynamic analysis” to any Merge Requests or Issues to ensure the Dynamic Analysis team sees your contribution.
Community contributions should get prompt feedback from one of the DAST engineers. All engineers on the DAST team are responsible for working with community contributions. If a team member does not have time to review a community contribution, please tag the Engineering Manager, so that they can assign the community contribution to another team member.
Dashboards
Targets
For our Merge Request types, we have an initial soft target ratio of 60% features, 30% maintenance, and 10% bugs based on the cross-functional prioritization process. This is not a hard target and we expect to see variation in this ratio as we mature and our focus evolves.
55741fb9
)