Skip to content

Repository for hosting interview pairing sessions

Notifications You must be signed in to change notification settings

OpenPhone/interviews

 
 

Repository files navigation

OpenPhone Technical Interviews

Open in GitHub Codespaces

This repository contains information about the OpenPhone 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 technical interview process typically consists of the following steps:

  1. Meeting You
  2. Hiring manager interview
  3. Virtual technical pairing sessions
  4. System design

Meeting You

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

Hiring Manager

You'll meet with the hiring manager for the role through a call or virtual hangout. You'll have a chance to learn more about the OpenPhone Engineering team and the role, as well as better understand the experience we're looking for.

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.

We use GitHub CodeSpaces to provide pairing sessions in your web browser or in Visual Studio Code.

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

System Design

There are multiple ways to design a system, and these interviews are all about checking if the candidate can take the best or most optimized approach to make the system work. We'll either design a new system or review an existing one to gauge your ability to understand the system's trade-offs, complexities, or limitations.

We use Lucidchart for diagramming. We'll ask you to create a free Lucidchart account before the interview.

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.

Codespaces will automatically delete after 7 days. You can manually 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.

About

Repository for hosting interview pairing sessions

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HCL 28.9%
  • Shell 23.2%
  • TypeScript 15.0%
  • CSS 8.3%
  • Jupyter Notebook 6.3%
  • Go 6.0%
  • Other 12.3%