StackShareStackShare
Follow on
StackShare

Discover and share technology stacks from companies around the world.

Follow on

© 2025 StackShare. All rights reserved.

Product

  • Stacks
  • Tools
  • Feed

Company

  • About
  • Contact

Legal

  • Privacy Policy
  • Terms of Service
  1. Home
  2. Companies
  3. SourceLevel
SourceLevel logo

SourceLevel

Verified

SourceLevel provides metrics and insights from GitHub and GitLab, including Lead Time, Throughput, Engagement, and Collaboration. Our product brings visibility over every corner of the delivery pipeline in a Data & Analytics Solution for Engineering Ops.

Walnut, CAsourcelevel.io
45
Tools
5
Decisions
0
Followers

Tech Stack

Application & Data

15 tools

NGINX logo
NGINX
Ruby logo
Ruby
Rails logo
Rails
PostgreSQL logo
PostgreSQL
Docker logo
Docker
JavaScript logo
JavaScript
HTML5 logo
HTML5
ES6 logo
ES6
Zoom logo
Zoom
Passenger logo
Passenger
Redis logo
Redis
Sass logo
Sass
Elixir logo
Elixir
Docker Compose logo
Docker Compose
Docker Hub logo
Docker Hub

Utilities

10 tools

Sidekiq logo
Sidekiq
Amplitude logo
Amplitude
Google Analytics logo
Google Analytics
Slack logo
Slack
Stripe logo
Stripe
ProfitWell logo
ProfitWell
Segment logo
Segment
Postmark logo
Postmark
1Password logo
1Password
Postman logo
Postman

DevOps

13 tools

GitHub logo
GitHub
CircleCI logo
CircleCI
AppSignal logo
AppSignal
Stackdriver logo
Stackdriver
Rollbar logo
Rollbar
UptimeRobot logo
UptimeRobot
Capistrano logo
Capistrano
Git logo
Git
Terraform logo
Terraform
Ansible logo
Ansible
Packer logo
Packer
SourceLevel logo
SourceLevel
RuboCop logo
RuboCop

Business Tools

7 tools

Figma logo
Figma
Miro logo
Miro
Shortcut logo
Shortcut
FullStory logo
FullStory
HubSpot logo
HubSpot
G Suite logo
G Suite
Drift logo
Drift

Team Members

Bruna Goss
Bruna Goss
Weverton Timoteo
Weverton TimoteoCTO
Gustavo Araújo
Gustavo AraújoSoftware Developer
Gustavo Dutra
Gustavo DutraProduct Manager
Beatriz Chagas
Beatriz ChagasRuby Developer

Engineering Blog

Stack Decisions

Weverton Timoteo
Weverton Timoteo

Aug 17, 2020

12 Ruby Gems We use at SourceLevel and Why:

Text Handling & Formatting

We are heavy Markdown users! We produce internal documentation in Markdown. The docs page is a static site entirely written in it (and built with Middleman).

In the main app, we use markerb to parse markdown content and convert it to HTML. Comments to Github, issue explanations and repository badges are examples of markdown usage. Although its repository is archived and doesn’t accept contributions anymore, it does a pretty good job. It works with both kramdown and redcarpet. We chose redcapet as our processor.

Another useful gem is charlock_holmes. As accurate as Sir Arthur’s character Sherlock Holmes, this gem detects character encoding for given files or chunks of text. Under the hood, charlock_holmes benefits from the set of libraries from ICU.

Database & Storage

We love PostgreSQL! It is reliable, open-source and has lots of functionalities that make it attractive. The ability to create materialized views is one of them.

Working with views in Rails is kind of messy. That’s why we added scenic to the SourceLevel main app. This gem adds methods to ActiveRecord::Migration that allow managing views in migrations.

We use materialized views to scope content. If you don’t know what it is, here it goes: it’s a SQL query whose results work as stored in a regular table. Long-running queries or segmented results can be fetched from appropriate views reducing both time and code complexity.

pghero gem, besides the ability to kill them if you need, also ships with a UI for you to monitor other performance indicators.

Another essential dependency is dalli. It does an incredibly good job of storing and retrieving memcached records. It’s thread-safe and allows us to run Rails.cache smoothly throughout the codebase.

Read more in our blog post :)

5k views5k
Comments
Weverton Timoteo
Weverton Timoteo

Aug 10, 2020

To communicate isn’t just getting rid of syntax errors and making code work. The code should communicate ideas to people through a programming language that computers can also understand.

You should adopt semantic variables, classes, modules, and methods names. For instance, in Ruby, we avoid using particular prefixes such as is_paid, get_name and set_name. In their places, we use directly paid?, name, and name=.

My advice is to use idiomatic and features that the programming language you use offers to you whenever possible, and figure out ways to better pass the message.

Why wouldn’t we be worried about semantics, typos, and styles? We should care for the quality of our code, and the many concepts that define it. You can start by using a #linter to collect some issues from your codebase automatically.

116k views116k
Comments
Weverton Timoteo
Weverton Timoteo

Aug 3, 2020

Do you review your Pull/Merge Request before assigning Reviewers?

If you work in a team opening a Pull Request (or Merge Request) looks appropriate. However, have you ever thought about opening a Pull/Merge Request when working by yourself? Here's a checklist of things you can review in your own:

  • Pick the correct target branch
  • Make Drafts explicit
  • Name things properly
  • Ask help for tools
  • Remove the noise
  • Fetch necessary data
  • Understand Mergeability
  • Pass the message
  • Add screenshots
  • Be found in the future
  • Comment inline in your changes

Read the blog post for more detailed explanation for each item :D

What else do you review before asking for code review?

1.19M views1.19M
Comments
Weverton Timoteo
Weverton Timoteo

Jul 28, 2020

Using an inclusive language is crucial for fostering a diverse culture. Git has changed the naming conventions to be more language-inclusive, and so you should change. Our development tools, like GitHub and GitLab, already supports the change.

SourceLevel deals very nicely with repositories that changed the master branch to a more appropriate word. Besides, you can use the grep linter the look for exclusive terms contained in the source code.

As the inclusive language gap may happen in other aspects of our lives, have you already thought about them?

944k views944k
Comments
Weverton Timoteo
Weverton Timoteo

Jul 22, 2020

One of the magic tricks git performs is the ability to rewrite log history. You can do it in many ways, but git rebase -i is the one I most use. With this command, It’s possible to switch commits order, remove a commit, squash two or more commits, or edit, for instance.

It’s particularly useful to run it before opening a pull request. It allows developers to “clean up” the mess and organize commits before submitting to review. If you follow the practice 3 and 4, then the list of commits should look very similar to a task list. It should reveal the rationale you had, telling the story of how you end up with that final code.

1.1M views1.1M
Comments