Skip to content

Instantly share code, notes, and snippets.

@Joelkw
Last active November 14, 2022 18:24
Show Gist options
  • Save Joelkw/f0582b164578aabc3ac936dee43f23e0 to your computer and use it in GitHub Desktop.
Save Joelkw/f0582b164578aabc3ac936dee43f23e0 to your computer and use it in GitHub Desktop.
Quickstart guide to Sourcegraph code insights prototypes

Sourcegraph Search Query Code Insights [Prototype] - documentation

This document is no longer relevant and is 10 months out of date: Code Insights is now in beta. If you are customer/early access user, please reach out to your Sourcegraph contact for documentation.

This is a prototype (Considerations)

This is a prototype, and it's not yet optimized.

For example, a search insight runs all the search queries on the frontend and tries to cache them – it may take awhile on first view but less time on subsequent views. The number of queries to run is (number of repos in your repo list) x (number of steps). The number of steps is currently hardcoded to 7. If you're running into loading time issues, first try limiting the number of repos.

Please do slack/email Joel Kwartler (@joel slack; @joelkw github; joel@sourcegraph.com) with feedback, bugs, and feature requests.

Code Insights Splash

1. Enable the experimental feature flag

Add the following to your Sourcegraph user /users/[username]/settings or organization /organizations/[your_org]/settings settings:

"experimentalFeatures": { "codeInsights": true }

2. Enable the extension

Visit the search insights extension page and enable it.

3. Configure your first insight

Configure the insight by adding the following structure to your user, org, or global settings (but not in your site configuration settings):

// Choose any name - only the prefix "searchInsights.insight." is mandatory.
"searchInsights.insight.uniqueNameForYourInsight": {

  // Shown as the title of the insight.
  "title": "Migration to React function components",

  // a list of repositories to run the search over
  "repositories": ["github.com/sourcegraph/sourcegraph"],

  // The lines of the chart.
  "series": [
    {
      // Name shown in the legend and tooltip.
      "name": "Function components",

      // The search query that will be run for the interval defined in "step".
      // Do not include the "repo:" filter as it will be added automatically for the current repository. Example query
      "query": "patternType:regexp const\\s\\w+:\\s(React\\.)?FunctionComponent",

      // An optional color for the line.
      // Can be any hex color code, rgb(), hsl(),
      // or reference color variables from the OpenColor palette (recommended): https://yeun.github.io/open-color/
      // The semantic colors var(--danger), var(--warning) and var(--info) are also available.
      "stroke": "var(--oc-teal-7)"
    },
    {
      // this is a second series on the same chart 
      "name": "Class components",
      "query": "patternType:regexp extends\\s(React\\.)?(Pure)?Component",
      "stroke": "var(--oc-indigo-7)"
    }
  ],
  // The step between two data points. Supports days, months, hours, etc.
  "step": {
    "weeks": 2
  }
}

4. View your insight

The insight will appear on your insights page (YourSourcegraphUrl.com/insights) as well as below the search bar on the home page and on directory pages.

Regardless of whether you define a repo, the insight will show up on every directory page (and run for that directory). With repos listed, it will also show up on the /insights and search pages. Without listing repos, it will show nothing on those two pages.

If you put these settings in your org settings, everyone will see them on the /insights page. If you put them in your personal settings, only you will see them there.

On Sourcegraph 3.26 or later, you can control which of those locations insights display with three additional settings feature flags placed in your settings as a sibling of the searchInsights.insight object (not within it):

"insights.displayLocation.homepage": false,
"insights.displayLocation.insightsPage": true,
"insights.displayLocation.directory": true

If not set, these display settings default to true.

5. Configure additional insights

Multiple search insights can be defined by adding more objects under different keys, as long as they are prefixed with searchInsights.insight. .

6. Other insights

Sourcegraph also has language usage insights, which adds a pie chart of lines of code by language to your directory and insights page.

The setup is similar, and you enable the extension and then add to your user or global settings:

// Title
"codeStatsInsights.title": "Language usage",

// The file query to limit the global insights page to (here it's limited to a repo)
"codeStatsInsights.query": "repo:^github\\.com/sourcegraph/sourcegraph$",

// The threshold for grouping all other languages into an "other" category
"codeStatsInsights.otherThreshold": 0.02,

Please do slack/email Joel Kwartler (@joel slack; @joelkw github; joel@sourcegraph.com) with any feedback, bugs, and feature requests!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment