/interviews

Repository for hosting interview pairing sessions

Primary LanguageTypeScript

Source Allies Interviews

Open in GitHub Codespaces

This repository contains information about the Source Allies pairing session process.

Please see our careers page if you are interested in working on our team!

This repo is part of an active effort to make our pairing session process more transparent. We are continuously improving our interview process to make it more effective.

Typical Interview Process

Our pairing process typically consists of four steps:

  1. Meeting You
  2. Self Evalutation
  3. A custom HackerRank coding exercise
  4. In-person (or virtual) technical pairing session

Meeting You

You’ll meet with a recruiter through a call, virtual hangout, or even a coffee. You will connect and talk about your background, where you would like to grow your career, and what drew you to Source Allies. This conversation is to gain an understanding of initial alignment for both parties.

Self Evaluation

This document will be a chance for you to tell stories and share with Source Allies a more in-depth snapshot of your experience and perspectives. There will also be a confidential information component that is shared only between you and your recruiter.

Coding Exercise

This is an algorithmic coding exercise via HackerRank to get a better glimpse of your technical capabilities. The test consists of front and backend question options, and a variety of languages, frameworks, and libraries to utilize. Are you up for the challenge?

Pairing Session

The purpose of this interview is to further gauge your technical ability and to get a sense of what it’s like to work with you.

We use a project to guide our discussion, but we don't have to finish the project. We only need to get far enough along to get a good sense of your technical ability.

To create a positive experience for virtual pairing sessions, please have reliable camera and audio ready.

How to use this repo for the pairing session

This repository serves as an entrypoint to be able to easily spin up an environment for many straightforward languages/projects by leveraging VSCode devcontainers and codespaces.

If you would like a 1 click process to work in one of these languages, it is easiest to leverage codespaces. This will create a vscode instance running on a VM in the cloud you can use to interact with this codebase. It will contain all dependencies and extensions to need to work in all of these languages, and can be disposed of after the interview, or practice sessions before hand.

Typically, the interviewer will start the code space, then the interviewee will join via liveshare. However, this is not a hard and fast rule. Feel free to leverage codespaces to run this yourself if you would like.

You can also use the dev containers extension for your local VSCode installation to be able to run this, however, it will take a few minutes to pull the needed docker image and get set up, so plan accordingly.

Using Codespaces

If using codespaces click this badge.

Open in GitHub Codespaces

Here, you have a few options.

Option 1: Use a project specific devcontainer. This will automatically add extensions related to this project, as well do any prep work like running mvn, npm, or poetry install commands via make init. This is recommended if you are only working in 1 project. You will need to navigate to the desired project folder and you should be able to run make verify to see test output.

Option 2: Use the Default devcontainer. If you use this option, you will have all the technology you need to run anything in the repo, but you will have no extensions installed by default except Live Share, and will need to navigate to your desired project and run make init to perform any setup.

Launch Codespace

After you choose either option you should be greeted with a very short building process, followed by VSCode launching in a new broswer tab.

Codespace Launching

If you chose Option 1, extensions will now initialize, and an init script will run in the background, preparing your project.

You are now ready to start the pairing session!

Optional Tools

Because pairing sessions can widely vary, we have tried to include many options of languages, and well as common frameworks. In addition, there is a docker-compose.yml file in the root of this directory that can easily be used to launch a Postgres database, an instance of Localstack, or both. This is so you can integrate with these services from your pairing project if desired.

To launch both services you can run: docker compose up -d, or to launch one, simply add the name of the service as it is defined in the compose file.

What is in each project?

Each project is kept extremely simple. There is usually a README describing the project tech stack, a main class or logic of some kind, as well as a test to make sure this logic can execute correctly. Depending on the framework or language, there may also be files to set up required libraries, such as a pom.xml, package.json, or pyproject.toml. In addition, each project contains a Make file that will let you run familiar commands, regardless of current language:

  • make init - Run any setup that this project may need, like installation scripts. This is already done for you by the baseline init script when the codespace starts, but can be leveraged when you move to other projects if you want.
  • make verify - Run the built in tests for this project.
  • make run - OPTIONAL: When present, this is to run the project in interactive mode, like when a server is launched using Spring Boot or React.

For the Interviewer

Typically, the interviewer will start the codespace, then the interviewee will join via liveshare, which can easily be launched on the web or on their local VSCode. It is recommended to start up the devcontainer prior to the pairing session to let everything load (At most, it can take up to 2 minutes to fully load all extensions).

Every GitHub user has 120 free core hours of codespaces available per month, which will be hard to go over unless you are using codespaces outside of interviewing. You should not have to worry about being charged for usage unless you explicitly set a spending limit. If you would like to avoid using codespaces, you are welcome to get this repo running locally using VSCode, docker, and the remote containers extension.

If you decide to use codespaces, we would encourage you to delete your running codespace after the interview by visiting this link. Note: deleting the codespace will remove all files so make sure you've finished your review prior to deleting the codespace.

As always, feel free to reach out if anything in the process is causing problems or concern.

Troubleshooting

If something doesn't seem quite right with the codespace once it's up and running you can type devcontainer-info in a console to see some information about the current configuration. devcontainer-info should tell you the version of the image you're running, source code location, build timestamps, and a link to a Markdown file showing what versions of different tools are installed on the current image.