semgrep VS Enzyme

Compare semgrep vs Enzyme and see what are their differences.

Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
semgrep Enzyme
74 33
9,688 19,967
2.2% -0.1%
9.9 6.7
7 days ago 2 months ago
OCaml JavaScript
GNU Lesser General Public License v3.0 only MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

semgrep

Posts with mentions or reviews of semgrep. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-16.
  • A Deep Dive Into Terraform Static Code Analysis Tools: Features and Comparisons
    6 projects | dev.to | 16 Apr 2024
    Semgrep OSS Owner/Maintainer: Semgrep Age: First release on GitHub on February 6th, 2020 License: GNU Lesser General Public License v2.1
  • Semgrep – Find bugs and enforce code standards
    1 project | news.ycombinator.com | 9 Apr 2024
  • Application Security - Bridging Frontend and Cybersecurity: What is Application Security?
    1 project | dev.to | 2 Apr 2024
    Semgrep - https://semgrep.dev
  • Creating a DevSecOps pipeline with Jenkins — Part 1
    3 projects | dev.to | 17 Mar 2024
    For the SAST stage, I used SonarQube tool. SonarQube is an open-source platform developed by SonarSource for continuous inspection of code quality to perform automatic reviews with static analysis of code to detect bugs and code smells on more than 30 programming languages. I preferred SonarQube instead of other SAST tools because it has a detailed documentation and plugins about integration with Jenkins and SonarQube works with Java projects pretty well. Of course you can similar multi-language-supported tools such as Semgrep or language-specific tools such as Bandit.
  • Tree-Sitter
    4 projects | news.ycombinator.com | 17 Feb 2024
    > Not sure I understand your point.

    The problem is using Treesitter (for syntax highlighting and "semantic movements") and an LSP at the same time. So if your language has a LSP, using Treesitter additionally is redundant at best and introduces inconcistency at worst.

    I'm not talking about using Treesitter as the parser for the LSP.

    > Most popular languages have language-specific tools

    I'd say even less popular langauges like Coq^H^H^HRocq, Lean 4, Koka, Idris, Unison, ... have their "own" tools, I do not know of a language that uses a Treesitter parser in its LSP, but I do know about tools like https://semgrep.dev/ (written in OCaml) and Github's code search which use Treesitter.

  • AST-grep(sg) is a CLI tool for code structural search, lint, and rewriting
    15 projects | news.ycombinator.com | 10 Dec 2023
    Well, when I seach for "semgrep", I get a very nice corporate landing page with a "Book Demo" button. Which is a level of hassle that just isn't worth it for smaller teams, because "Book Demo" usually means "We're going to try to do a dance to see how much money we can extract from you." Which smaller teams may only want to do for a handful of key tools.

    (4 years ago, I was more willing to put up with enterprise licensing. But in the last two years, I've seen way too many enterprise vendors try to squeeze every penny they can get from existing clients. An enterprise sales process now often means "Expect 30% annual price hikes once you're in too deep to back out.")

    There's also an open source "semgrep" project here: https://github.com/semgrep/semgrep. But this seems to be basically a vulernability scanner, going by the README.

    Whereas AST-grep seems to focus heavily on things like:

    1. One-off searching: "Search my tree for this pattern."

    2. Refactoring: "Replace this pattern with this other pattern."

    AST-grep also includes a vulnerability scanning mode like semgrep.

    It's possible that semgrep also has nice support for (1) and (2), but it isn't clearly visible on their corporate landing page or the first open source README I found.

  • Top 10 Snyk Alternatives for Code Security
    3 projects | dev.to | 31 Aug 2023
    7. Semgrep
  • Semgrep: Semantic Grep for Code
    1 project | news.ycombinator.com | 4 Aug 2023
  • semgrep VS bearer - a user suggested alternative
    2 projects | 10 Jul 2023
  • Powerful SAST project for Android Application Security
    3 projects | /r/bugbounty | 21 Jun 2023
    This project is a compilation of Semgrep rules derived from the OWASP Mobile Application Security Testing Guide (MASTG) specifically for Android applications. The aim is to enhance and support Mobile Application Penetration Testing (MAPT) activities conducted by the ethical hacker community. The primary objective of these rules is to address the static tests outlined in the OWASP MASTG.

Enzyme

Posts with mentions or reviews of Enzyme. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-22.
  • The best testing strategies for frontends
    8 projects | dev.to | 22 Apr 2024
    Probably Enzyme was the first to popularize component testing in React by doing shallow rendering and expecting some things to be there in the React component tree. Then React Testing library came and took component testing to a whole new level.
  • Testing React Components: A Comprehensive Overview of Testing Libraries
    2 projects | dev.to | 15 Oct 2023
    Enzyme is another popular testing utility for React. It allows you to manipulate and traverse React components' output, making it easier to write comprehensive tests.
  • Speeding up the JavaScript ecosystem – Polyfills gone rogue
    11 projects | news.ycombinator.com | 21 Sep 2023
    ljharb is an extremely interesting person. There’s no doubting the positive impact he’s had on the OSS community and the work he’s done.

    However, there are some things he does that are incomprehensible.

    For example, Enzyme. Over three years ago this issue was opened for Enzyme on React 17: https://github.com/enzymejs/enzyme/issues/2429

    Nothing moved for a while, and I think he said something along the lines of “if you want React 17 support, stop complaining and help”. So the community got involved. There are multiple PRs adding React 17 support. Many unofficial React 17 adapters. A lot of people have put a lot of work into this, ensuring compatibility, coverage etc. Yet to this day, none of them have been merged. Eg https://github.com/enzymejs/enzyme/pull/2564

    Given the amount of time that has passed, and the work the community has put in, something is amiss. It feels like he’s now intentionally avoiding React 17+ support. But why? I don’t understand why someone would ask for help then ignore the help when it comes in. That isn’t much better than the swathe of rude/entitled comments he was getting on the issue before he locked it.

    I ended up migrating to RTL, but this made many of my tests more complicated (especially compared to shallow rendering).

  • Mastering React Testing: A Comprehensive Guide to Jest, Enzyme, and React Testing Library
    2 projects | dev.to | 3 Jun 2023
    Enzyme Documentation
  • How To Scale Your React Applications
    5 projects | dev.to | 7 Apr 2023
    One way to do this is by writing tests for your React components. Tools like Jest and Enzyme make it easy to test your component's behavior, rendering output, and state changes. By writing tests for your components, you can ensure that they behave as expected and prevent issues before they reach production.
  • Top OpenAI Tools, Examples & Use Cases
    6 projects | dev.to | 6 Feb 2023
    GitHub link: https://github.com/enzymejs/enzyme
  • How to Confidently Write Unit Tests using React Testing Library
    7 projects | dev.to | 1 Dec 2022
    So If you have experience with enzyme testing, where you might be checking the value of state once you click any button or you might be checking the prop value If something changes.
  • Difference Between JEST and Enzyme?
    2 projects | dev.to | 17 Oct 2022
    Enzyme offers two types of API for shallow rendering and full rendering. Both are preferred for different test scenarios and functionalities.
  • Testing with Jest and React Testing Library
    6 projects | dev.to | 18 Sep 2022
    At Visa, I was writing unit tests for a Next.js project using components designed with Chakra UI. That's where React Testing Library came in handy. Unlike other solutions like Enzyme, I did not have to worry about the application snapshot but could instead focus on each UI element, its expected behaviour and the data it would render upon user interactions.
  • Superset: Testing and Enzyme to RTL conversion
    4 projects | dev.to | 31 May 2022
    Superset uses Jest and React Testing Library (RTL) to write unit and integration tests. In the past we used Enzyme, but now that we're currently converting all of our class components to functional components, Enzyme cannot support our testing needs. Since RTL is better for testing functional components, we're converting all of our test files to RTL. This can be quite a learning curve - I've gone through a lot of the process so I'd like to share what I've learned so far.

What are some alternatives?

When comparing semgrep and Enzyme you can also consider the following projects:

SonarQube - Continuous Inspection

react-testing-library - 🐐 Simple and complete React DOM testing utilities that encourage good testing practices.

snyk - Snyk CLI scans and monitors your projects for security vulnerabilities. [Moved to: https://github.com/snyk/cli]

Sinon.JS - Test spies, stubs and mocks for JavaScript.

codeql - CodeQL: the libraries and queries that power security researchers around the world, as well as code scanning in GitHub Advanced Security

WebdriverIO - Next-gen browser and mobile automation test framework for Node.js

Spotbugs - SpotBugs is FindBugs' successor. A tool for static analysis to look for bugs in Java code.

jest - Delightful JavaScript Testing.

pre-commit - A framework for managing and maintaining multi-language pre-commit hooks.

react-hook-form - 📋 React Hooks for form state management and validation (Web + React Native)

detect-secrets - An enterprise friendly way of detecting and preventing secrets in code.

Jooks (Jest ❤ + Hooks 🤘🏻) - Testing hooks with Jest