freeCodeCamp/docs/how-to-catch-outgoing-emails-locally.md
Oliver Eyton-Williams c8d7f0a782
feat(tools): remove eslint-plugin-prettier for prettier (#42438)
* feat: remove eslint-plugin-prettier for prettier

This removes the annoying lint warnings when all that needs to change is
formatting

* fix: use .js lint-staged config to ignore properly

* fix: lint everything if a lot of files are changed

It's faster than making lots of individual linter calls

* chore: apply prettier

* fix: ignore code in curriculum-file-structure
2021-10-06 21:02:21 +05:30

4.0 KiB

Note: This is an optional step and is required only when working with email workflows

Introduction

Some email workflows, like updating a user's email, requires the back-end api-server to send outgoing emails. MailHog is an alternative to using an email service provider to send actual email messages. It is a developer tool for email testing that will catch the email messages sent by your freeCodeCamp instance.

Installing MailHog

MailHog can be installed on macOS, Windows and Linux or used via Docker

Installing MailHog with Docker

If you have Docker installed then you can use

docker run -d --name mailhog --network host --rm mailhog/mailhog

to start MailHog in the background and

docker stop mailhog

to stop it.

When the installation completes, you can start using MailHog.

Installing MailHog on macOS

Install MailHog on macOS with Homebrew:

brew install mailhog
brew services start mailhog

The above commands will start a mailhog service in the background.

When the installation completes, you can start using MailHog.

Installing MailHog on Windows

Download the latest version of MailHog from MailHog's official repository. Locate and click on the link for your Windows version (32 or 64 bit) and a .exe file will be downloaded to your computer.

When the download completes, click to open the file. A Windows firewall notification may appear, requesting access permission for MailHog. A standard Windows command line prompt will open where MailHog will be running once firewall access is granted.

Close MailHog by closing the command prompt window. To start MailHog again, click on the MailHog executable (.exe) file that was downloaded initially - it is not necessary to download a new MailHog installation file.

Start using MailHog.

Installing MailHog on Linux

First, install Go.

Run the following commands to install GO on Debian-based systems like Ubuntu and Linux Mint.

sudo apt-get install golang

Run the following commands to install GO on RPM-based systems like CentOS, Fedora, Red Hat Linux, etc.

sudo dnf install golang

Alternatively, run the following commands to install GO.

sudo yum install golang

Now set the path for Go with the following commands.

echo "export GOPATH=$HOME/go" >> ~/.profile
echo 'export PATH=$PATH:/usr/local/go/bin:$GOPATH/bin' >> ~/.profile
source ~/.profile

Finally, enter the commands below to install and run MailHog.

go get github.com/mailhog/MailHog
sudo cp /home/$(whoami)/go/bin/MailHog /usr/local/bin/mailhog
mailhog

Start using MailHog.

Using MailHog

Open a new browser tab or window and navigate to http://localhost:8025 to open your MailHog inbox when the MailHog installation has completed and MailHog is running. The inbox will appear similar to the screenshot below.

MailHog Screenshot 1

Emails sent by your freeCodeCamp installation will appear as below

MailHog Screenshot 2

Two tabs that allow you to view either plain text or source content will be available when you open a given email. Ensure that the plain text tab is selected as below.

MailHog Screenshot 3

All links in the email should be clickable and resolve to their URL.

  • Check out the MailHog repository for further information related to MailHog. Additional information is also available regarding custom MailHog configurations.