Skip to main content

eatlocal helps the user solve PyBite code challenges on their local machine

Project description

forthebadge

eatlocal

Eatlocal helps the user solve PyBites code challenges locally. This cli tool allows you to download, unzip, and organize bites according to the expected structure from the directions on the PyBites website. You can display bite directions in the terminal. Once you have solved the bite you can use eatlocal to submit and it will open a bowser tab at the correct location.

Updates

version 0.8.1

  • Better warning messages
  • Faster downloads
  • New command: eatlocal init

Breaking Changes

  • With version 0.8.0 there is a new eatlocal init command. Use this to configure your credentials and local git repository. You no longer need to set environment variables manually.
  • When displaying a bite, there is no longer a live display. The directions and source code are printed to the console. This eliminated the need for the getkey library and made install eatlocal on windows easier.

DEMOS

Configure

gif of init command

Download Bites

gif of download command

Display Bites

gif of display command

Submit Bites

gif of submit command

Table of Contents

Usage

Set up your configuration file:

eatlocal init

Download and extract bites:

# use -V, --verbose to print what's happening
eatlocal download <bite number>

Display bites in the terminal:

# change the theme with -t <theme name>
eatlocal display <bite number>

Submit bites:

# use -V, --verbose to print what's happening
eatlocal submit <bite number>

Installation

macOS/Linux

pip3 install eatlocal

Windows

pip install eatlocal

Setup

  1. Go through the directions on the PyBites website to connect your GitHub account to your PyBites account. You will find the necessary steps under Settings in the navigation sidebar.
  2. Run eatlocal init to configure your PyBites username, PyBites password*, and local git repository.
  3. Make sure you have Chrome and chromedriver installed and on $PATH. The chromedriver version must match the version of your Chrome browser. Chromedriver downloads.

*Note: If you signed up for PyBites by authenticating through GitHub or Google, you may need to set a password manually in order to use eatlocal.

Install Chrome and Chromedriver

macOS

One option is to use homebrew homebrew.

Install chrome:

brew install --cask google-chrome

Install chromedriver:

brew install chromedriver

Before you run chromedriver for the first time (and after you update versions), you must explicitly give permission since the developer has not been verified. Running the following command in the terminal removes the warning put in place by Apple:

xattr -d com.apple.quarantine $(which chromedriver)

Homebrew automatically puts chromedriver on $PATH for you. And since homebrew handles both chrome and chromedriver installations for me, I can run brew update && brew upgrade to help ensure I have the same version number for both chrome and chromedriver. If you do not go the homebrew route, you must manually ensure that your version of chrome matches the version of chromedriver.

Linux

Navigate to the download page for google chrome and download the appropriate version for your system. Then, open up a terminal and navigate to where you downloaded the file. For me it was ~/Downloads. I ran the following commands to install and check which version I have.

cd ~/Downloads
sudo dpkg -i google-chrome-stable_current_amd64.deb
google-chrome --version

Next, navigate to the chromedriver download page and choose the version that matches the output from google-chrome --version. Download that file that matches your system. Head back to your terminal.

  1. Ensure that you have unzip installed:
sudo apt install unzip
  1. Unzip the chromedriver file. For me it was located in the downloads folder:
unzip ~/Downloads/chromedriver_linux64.zip -d ~/Downloads
  1. Make it executable and move to /usr/local/share:
chmod +x ~/Downloads/chromedriver
sudo mv -f ~/Downloads/chromedriver /usr/local/share/chromedriver
  1. Create symlinks:
sudo ln -s /usr/local/share/chromedriver /usr/local/bin/chromedriver
  1. Confirm you have access:
which chromedriver

Windows

If working in windows powershell you can use chocolately to install both Chrome and chromedriver (with matching versions).

I've found that in order to install packages I have to use an elevated administrative shell, with choco install chromedriver.

chromedriver in chocolatey

WSL

eatlocal does not work with WSL2. There seems to be an issue between WSL2 and google-chrome and chromedriver. Perhaps this will be resolved in the future with WSLg. For now, there is a workaround: Follow instructions for Windows users except install eatlocal globally. Using PowerShell or Windows Terminal, navigate to your WSL distribution's directory that holds your repository and initialize eatlocal from there. Now just download and submit through your external PowerShell command line instead of your bash terminal. Everything should still behave the same, you just can't use your WSL shell or your integrated terminal in VS Code.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

eatlocal-0.8.1.tar.gz (12.0 kB view details)

Uploaded Source

Built Distribution

eatlocal-0.8.1-py3-none-any.whl (10.6 kB view details)

Uploaded Python 3

File details

Details for the file eatlocal-0.8.1.tar.gz.

File metadata

  • Download URL: eatlocal-0.8.1.tar.gz
  • Upload date:
  • Size: 12.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.10.2 Darwin/21.4.0

File hashes

Hashes for eatlocal-0.8.1.tar.gz
Algorithm Hash digest
SHA256 409993c731eae1fec0b7995173c7d002a331124096ee498fea0ba102d13ebe9a
MD5 e0f3c7c74b35dfc24ba3c441a09f17d1
BLAKE2b-256 dae34ab9938c217376bcfe8764a5c0bb161b97c8d081d764ae3e1ff70adbcd2f

See more details on using hashes here.

File details

Details for the file eatlocal-0.8.1-py3-none-any.whl.

File metadata

  • Download URL: eatlocal-0.8.1-py3-none-any.whl
  • Upload date:
  • Size: 10.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.10.2 Darwin/21.4.0

File hashes

Hashes for eatlocal-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 838af08e1cb26f42df62c73ef267f79ec17309c6c297dc8754a5c641845df50f
MD5 95f58517dfc7dfec1fb07370f0e4d9a0
BLAKE2b-256 3b411000ac62238858af4bb44095e4530bead0e2e2350e201f5af22842e0807c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page