Proposing a change for caesar.spec.js for test 3 ('works with phrases') and test 4 ('works with negative shift'). The test for 'wraps' is supposed to come after these ones, but currently using the word "World!" in the earlier tests with a 5 key shift will require that wraps are already working, thus the spec test will fail even if the code is appropriate for phrases and negative shifts. If the learning process is to move one by one progressively through the spec tests, then I think it would be better not to require wraps to be working until the actual 'wraps' requirement in test 5. I believe simply replacing the word "World!" with "There!" should solve the issue. |
||
---|---|---|
caesar | ||
calculator | ||
fibonacci | ||
findTheOldest | ||
generator-exercise | ||
getTheTitles | ||
helloWorld | ||
leapYears | ||
palindromes | ||
pig_latin | ||
removeFromArray | ||
repeatString | ||
reverseString | ||
snakeCase | ||
sumAll | ||
tempConversion | ||
.gitignore | ||
README.md |
README.md
These are a series of javascript exercises intended to be used alongside the curriculum at 'The Odin Project' They start very simply, but get more involved as you progress through them.
There will eventually be a suggested order of completion, but at this time since we are still in the process of creating more exercises the order is subject to change and has not yet been specified... In general however there are a couple which make a good "starting point" feel free to at least start with these:
- Hello World
- Repeat String
- Reverse String
HOW TO USE THESE EXERCISES
Before you start you should have a few things installed on your machine:
- NPM. To check if you have NPM, type
npm --version
in a terminal. If you get backCommand 'npm' not found, but can be installed with:
, do NOT follow the instructions in the terminal to install withapt-get
(this causes permission issues). Instead, install NPM/Node with NVM by following the instructions here. - Jasmine. Jasmine is a testing framework for Javascript. Type
jasmine -v
to check for it. If you need to install it, typenpm install -g jasmine
to do so. - Clone this repo and get started.
Each exercise includes 3 files, a markdown file with a description of the task, an empty (or mostly empty) javascript file, and a set of tests. To complete the exercise go to the exercise directory with cd helloWorld
in a terminal and run jasmine filename.spec.js
. This should find and run the test file and show you the output. Upon first running the tests you will find that the tests fail: this is by design! Your task is to open up the javascript file and write the code needed to get all of the tests to pass. Some of the exercises have test conditions defined in the spec file that are defined as 'xit' compared to 'it'. This is purposeful, and as you test your solution against the first 'it', on success you will change the next 'xit' to an 'it' and test your code again, until all conditions are satisfied.
The first exercise, helloWorld
will walk you through the process in more depth.
Solutions
Solutions for these exercises can be found in this repo on the 'solutions' branch.
a quick note!
The generator exercise is not actually an exercise… it is a script that generates exercises. I was using it when I wrote them so I didn’t have to hack out the same boilerplate code every time I wrote a new one.