- Learn about testing in JavaScript
Many of the labs you will complete in this program use tests. Passing the tests verifies that the code you write behaves as desired and produces the expected results. But writing tests is also a way to provide specifics about exactly how the code should function. In a common development strategy known as test-driven development (or TDD), programmers first write the test for a specific function of the code then write the code to make the tests pass. TDD is considered the most reliable methodology for delivering quality code.
What this means is that the results of running the tests will be an important tool in figuring out how to get those tests passing. Code testing can feel like an abstract concept at first, but it's worth starting to learn how it works. When you're having difficulty passing a test, being able to read and understand the test output — and the tests themselves — can be an invaluable skill.
The lesson is set up as a code-along, so you'll first need to fork and clone it to your local environment.
Quick Review:
1. Click the Octocat icon in the upper right of this page. This will bring you to GitHub. Click the Fork button. If necessary, select your personal GitHub account as the Owner of the new fork. Click the Create fork button.
2. Once your fork is created, click the Code button in GitHub, make sure SSH is selected, and copy the provided git URL info.
Then, in your terminal:
3. Make sure you're in Development/code/se-prep
(or wherever you're
storing your code for the course) and clone the repo to your local machine with
git clone
followed by the git URL you copied.
$ git clone git@github.com:your-github-username/phase-0-pac-3-what-is-a-test.git
REMEMBER: Don't type the
$
. That's the universal symbol for a command prompt. It's how technical documentation says "Here's a thing for the shell to process."
4. The previous command will create a folder in the se-prep
folder
containing your fork of this lab's repository. cd
into the repository that you
just cloned down in the terminal, then run code .
to open the files in Visual
Studio Code.
$ cd phase-0-pac-3-what-is-a-test
$ code .
Open up index.js
in your code editor. You are going to see mostly familiar
things:
const name = "Joe";
const height = 74;
const message = `${name} is ${height} inches tall`;
module.exports = { name, height, message };
This should all look familiar except for that last line. You don't need to worry about it for now — just know that line of code makes the variables available to the test file.
Take a look at the message
variable:
const message = `${name} is ${height} inches tall`;
We can use console.log
to take a look at the value of the message
variable.
To do that, first type console.log(message);
on the last line of index.js
and save the file. Next, navigate to the terminal, and type the following
command in the command line and hit enter (be sure you're still in the lab's
directory):
$ node index.js
The node
command executes the code in whatever file you specify (in this
case, index.js
). You should see "Joe is 74 inches tall"
logged in the
terminal.
Top Tip:
console.log
is one of the debugging tools you can use as you're writing your code. Logging a variable and executing the code will allow you to verify that the value of the variable is what you're expecting.
In the line of code above, we are using string interpolation to inject the
values of the name
and height
variables into the message. Recall that, for
this to work, you have to wrap the entire string in backticks and wrap the
variables themselves in ${}
. If you'd like a refresher, try leaving out the
${}
s or switching to a different type of quotes and run your code again to see
what the value of message
is. The backticks and the ${}
tell Javascript to
grab the value inside the variable, not just that variable name.
We have our code, now let's take a look at the tests. They are located in the
test
folder inside a file named indexTest.js
. In this lesson we'll get
familiar with the tests, and then run them in the next lesson.
const { name, height, message } = require("../index.js");
/*
describe('what-is-a-test', () => {
describe('Name', () => {
it('returns "Susan"', () => {
expect(name).toEqual('Susan')
})
})
describe('Height', () => {
it('is less than 40', () => {
expect(height).toBeLessThan(40)
})
})
describe('Message', () => {
it('gives the name and height', () => {
expect(message).toInclude(name)
expect(message).toInclude(height)
})
})
})
*/
In the first line, we're enabling the tests to access the variables in
index.js
. You don't need to worry about exactly how this works at this point —
just know that the module.exports
and require
keywords allow us to access
variables written in the index.js
file from within the test file.
The next thing to notice is that the test code itself is commented out using the
/*
and */
block commenting syntax. This is because, as mentioned above, we
don't actually want to run the tests yet. We will run the tests in the lab that
follows this lesson; when you fork and clone that version of the files, you'll
see that the /*
and */
have been removed.
Next, note that the test code consists of three individual tests (each starting
with describe
) nested inside a block for the tests as a whole (also starting
with describe
).
The first grouping is testing our name
variable:
describe("Name", () => {
it('returns "Susan"', () => {
expect(name).toEqual("Susan");
});
});
Take a look at the line that begins with expect
. If we read it out loud, we
get "Expect name
to equal Susan". That's exactly what it's saying! If we
continue down to the Height section you'll see this code:
describe("Height", () => {
it("is less than 40", () => {
expect(height).toBeLessThan(40);
});
});
Again, reading the line starting with expect
out loud, we get "Expect height
to be less than 40." Again, this is just what the test is checking. Let's look
at the final one:
describe("Message", () => {
it("gives the name and height", () => {
expect(message).toInclude(name);
expect(message).toInclude(height);
});
});
This one has two expect
statements. If you read them out as English you'll
discover that the tests expect the value of index.message
to include both
index.name
and index.height
.
OK great. You now understand what the tests are saying. In the next lesson we are going to cover how to run them, and then you will solve the lab!
Even though you didn't need to write any code for this lesson, you'll still need to submit it using CodeGrade in order for it to be marked as complete in Canvas.
Scroll to the bottom of this lesson page in Canvas and click the button labeled "Load Testing With JavaScript in a new window".
In the CodeGrade window that opens, click "Create Submission". You should now see a list of your repositories. Find the repo for this lesson and click Connect. When you get the message that your repo has been connected, click on the embedded link, then the "AutoTest" tab. After a few moments, you should see the green checkmark in the "Pass" column, indicating that you've successfully submitted the lesson.