odin-default-js-exercises/caesar
Michael Frank 5708c3d85a Added jest
Removed generator-exercises folder as it breaks jest-codemods

run jest-codemods on .spec.js files, move generator-exercises back in

Change references from Jasmine to Jest in main readme

Update README with Jest specific language. Update some spec files with new syntax

update tests, multiple exercises

.gitignore: Added package-lock.json, package.json that were used when I ran code-blocks over the tests.

Standardised function declaration calls across exercises

fix typo in caesar.spec.js

Ignoring package-lock.json, package.json

Backtrack on .gitignore modification, add instructions to readme

move files from testing repo to this repo

Typo fixes, remove duplicate exercise folder

Remove solution from non-solution branch

Minor grammatical fixes

added trailing semicolon to all function and module exports

Fix words caught by search/replace action.

remove doubled semicolon.

Correct words caught by search/replace action.

Add missing semicolon.

Add .DS_Store to .gitignore

multiple files: Added a blank line at the end of each file

Ignore generator-exercise when linting exercise files

Update exercise number of each exercise

Update exercise number
2021-05-17 23:46:49 +01:00
..
.DS_Store Added test cases 2017-09-20 19:04:46 -04:00
README.md Added jest 2021-05-17 23:46:49 +01:00
caesar.js Added jest 2021-05-17 23:46:49 +01:00
caesar.spec.js Added jest 2021-05-17 23:46:49 +01:00

README.md

Exercise 13 - Caesar cipher

Implement the legendary Caesar cipher:

In cryptography, a Caesar cipher, also known as Caesar's cipher, the shift cipher, Caesar's code or Caesar shift, is one of the simplest and most widely known encryption techniques. It is a type of substitution cipher in which each letter in the plaintext is replaced by a letter some fixed number of positions down the alphabet. For example, with a left shift of 3, D would be replaced by A, E would become B, and so on. The method is named after Julius Caesar, who used it in his private correspondence.

Hint: You may need to convert letters to their unicode values. Be sure to read the documentation!

write a function that takes a string to be encoded and a shift factor and then returns the encoded string:

caesar('A', 1) // simply shifts the letter by 1: returns 'B'

the cipher should retain capitalization:

caesar('Hey', 5) // returns 'Mjd;

should not shift punctuation:

caesar('Hello, World!', 5) //returns 'Mjqqt, Btwqi!'

the shift should wrap around the alphabet:

caesar('Z', 1) // returns 'A'

negative numbers should work as well:

caesar('Mjqqt, Btwqi!', -5) // returns 'Hello, World!'