From 829730fb795abf5d10c15e18d201a57293e57072 Mon Sep 17 00:00:00 2001 From: Cody Loyd Date: Fri, 24 Nov 2017 14:23:16 -0600 Subject: [PATCH] Revert "remove class based exercises" This reverts commit 290e7f1da41641c3d028d0ef19669be35144a33a. --- book_titles/README.md | 3 ++ book_titles/bookTitles.js | 8 ++++ book_titles/bookTitles.spec.js | 64 +++++++++++++++++++++++++ helloWorld/helloWorld.js | 4 +- leapYears/leapYears.js | 7 +-- leapYears/leapYears.spec.js | 10 ++-- removeFromArray/removeFromArray.js | 12 +---- removeFromArray/removeFromArray.spec.js | 10 ++-- repeatString/README.md | 2 +- repeatString/repeatString.js | 9 +--- repeatString/repeatString.spec.js | 8 ++-- reverseString/reverseString.js | 6 +-- reverseString/reverseString.spec.js | 6 +-- sumAll/sumAll.js | 19 +------- sumAll/sumAll.spec.js | 10 ++-- timer/README.md | 11 +++++ timer/timer.js | 7 +++ timer/timer.spec.js | 35 ++++++++++++++ 18 files changed, 164 insertions(+), 67 deletions(-) create mode 100644 book_titles/README.md create mode 100644 book_titles/bookTitles.js create mode 100644 book_titles/bookTitles.spec.js create mode 100644 timer/README.md create mode 100644 timer/timer.js create mode 100644 timer/timer.spec.js diff --git a/book_titles/README.md b/book_titles/README.md new file mode 100644 index 0000000..acf79cf --- /dev/null +++ b/book_titles/README.md @@ -0,0 +1,3 @@ +The goal of this exercise is to introduce you to the concept of objects and classes. These are fundamental building blocks for OOP (Object Oriented Programming). You shouldn't need to write a ton of new code, in fact you can re-use your solution from the Simon Says exercise! + +The key here will be rewriting certain bits of it to work within the class given to you. \ No newline at end of file diff --git a/book_titles/bookTitles.js b/book_titles/bookTitles.js new file mode 100644 index 0000000..e546db0 --- /dev/null +++ b/book_titles/bookTitles.js @@ -0,0 +1,8 @@ +class bookTitle { + +} + +module.exports = { + bookTitle +} + diff --git a/book_titles/bookTitles.spec.js b/book_titles/bookTitles.spec.js new file mode 100644 index 0000000..3a0e8ad --- /dev/null +++ b/book_titles/bookTitles.spec.js @@ -0,0 +1,64 @@ +var bookTitles = require ('./bookTitles.js'); + +describe('bookTitle', function() { + + var book; // note the scope here, if you declare this inside beforeEach then the scope won't allow it to access the other specs + + beforeEach(function() { + book = new bookTitles.bookTitle(); // creates a new book instance before each test is run + }); + + describe('title', function() { + + it('should capitalize the first letter', function() { + book.title = 'inferno'; + expect(book.title).toEqual('Inferno'); + }); + + it('should capitalize every word', function() { + book.title = 'stuart little'; + expect(book.title).toEqual('Stuart Little'); + }); + + describe('should capitalize every word except...', function() { + describe('articles', function() { + it('does not capitalize "the"', function() { + book.title = 'alexander the great'; + expect(book.title).toEqual('Alexander the Great'); + }); + + it('does not capitalize "a"', function() { + book.title = 'to kill a mockingbird'; + expect(book.title).toEqual('To Kill a Mockingbird'); + }); + + it('does not capitalize "an"', function() { + book.title = 'to eat an apple a day'; + expect(book.title).toEqual('To Eat an Apple a Day'); + }); + }); + + it('conjunctions', function() { + book.title = 'war and peace'; + expect(book.title).toEqual('War and Peace'); + }); + + it('prepositions', function() { + book.title = 'love in the time of cholera'; + expect(book.title).toEqual('Love in the Time of Cholera'); + }); + }); + + describe('should always capitalize...', function() { + it('I', function() { + book.title = 'what i wish i knew when i was 20'; + expect(book.title).toEqual('What I Wish I Knew When I Was 20'); + }); + + it('the first word', function() { + book.title = 'the man in the iron mask'; + expect(book.title).toEqual('The Man in the Iron Mask'); + }); + }); + }); +}); \ No newline at end of file diff --git a/helloWorld/helloWorld.js b/helloWorld/helloWorld.js index 9029bef..cf8cd75 100644 --- a/helloWorld/helloWorld.js +++ b/helloWorld/helloWorld.js @@ -1,5 +1,5 @@ var helloWorld = function() { - return 'Hello, World!' + return '' } -module.exports = helloWorld +module.exports = helloWorld \ No newline at end of file diff --git a/leapYears/leapYears.js b/leapYears/leapYears.js index 9b55920..7884b78 100644 --- a/leapYears/leapYears.js +++ b/leapYears/leapYears.js @@ -1,8 +1,5 @@ -var leapYears = function(year) { - if (year % 4 !== 0 || (year % 100 == 0 && year % 400 != 0)) { - return false - } - return true +var leapYears = function() { + } module.exports = leapYears diff --git a/leapYears/leapYears.spec.js b/leapYears/leapYears.spec.js index 0af23c3..b58dadb 100644 --- a/leapYears/leapYears.spec.js +++ b/leapYears/leapYears.spec.js @@ -4,19 +4,19 @@ describe('leapYears', function() { it('works with non century years', function() { expect(leapYears(1996)).toEqual(true); }); - it('works with non century years', function() { + xit('works with non century years', function() { expect(leapYears(1997)).toEqual(false); }); - it('works with ridiculously futuristic non century years', function() { + xit('works with ridiculously futuristic non century years', function() { expect(leapYears(34992)).toEqual(true); }); - it('works with century years', function() { + xit('works with century years', function() { expect(leapYears(1900)).toEqual(false); }); - it('works with century years', function() { + xit('works with century years', function() { expect(leapYears(1600)).toEqual(true); }); - it('works with century years', function() { + xit('works with century years', function() { expect(leapYears(700)).toEqual(false); }); }); diff --git a/removeFromArray/removeFromArray.js b/removeFromArray/removeFromArray.js index ccb4343..d36b8b1 100644 --- a/removeFromArray/removeFromArray.js +++ b/removeFromArray/removeFromArray.js @@ -1,13 +1,5 @@ -var removeFromArray = function(array) { - elementsToRemove = [...arguments] - elementsToRemove.splice(0,1) - elementsToRemove.forEach(element => { - let index = array.indexOf(element) - if (index > -1) { - array.splice(index, 1) - } - }) - return array +var removeFromArray = function() { + } module.exports = removeFromArray diff --git a/removeFromArray/removeFromArray.spec.js b/removeFromArray/removeFromArray.spec.js index 9b5d9f9..ff94e9a 100644 --- a/removeFromArray/removeFromArray.spec.js +++ b/removeFromArray/removeFromArray.spec.js @@ -4,19 +4,19 @@ describe('removeFromArray', function() { it('removes a single value', function() { expect(removeFromArray([1, 2, 3, 4], 3)).toEqual([1, 2, 4]); }); - it('removes multiple values', function() { + xit('removes multiple values', function() { expect(removeFromArray([1, 2, 3, 4], 3, 2)).toEqual([1, 4]); }); - it('ignores non present values', function() { + xit('ignores non present values', function() { expect(removeFromArray([1, 2, 3, 4], 7, "tacos")).toEqual([1, 2, 3, 4]); }); - it('ignores non present values, but still works', function() { + xit('ignores non present values, but still works', function() { expect(removeFromArray([1, 2, 3, 4], 7, 2)).toEqual([1, 3, 4]); }); - it('can remove all values', function() { + xit('can remove all values', function() { expect(removeFromArray([1, 2, 3, 4], 1, 2, 3, 4)).toEqual([]); }); - it('works with strings', function() { + xit('works with strings', function() { expect(removeFromArray(["hey", 2, 3, "ho"], "hey", 3)).toEqual([2, "ho"]); }); }); diff --git a/repeatString/README.md b/repeatString/README.md index a58161a..70823e6 100644 --- a/repeatString/README.md +++ b/repeatString/README.md @@ -1,4 +1,4 @@ -# Exercis 02 - repeatString +# Exercise 02 - repeatString Write a function that simply repeats the string a given number of times: diff --git a/repeatString/repeatString.js b/repeatString/repeatString.js index e69f9d5..49dfa90 100644 --- a/repeatString/repeatString.js +++ b/repeatString/repeatString.js @@ -1,10 +1,5 @@ -var repeatString = function(string, num) { - if (num < 0) return 'ERROR' - let returnValue = '' - for(let i = 0; i < num; i++) { - returnValue = returnValue + string - } - return returnValue +var repeatString = function() { + } module.exports = repeatString diff --git a/repeatString/repeatString.spec.js b/repeatString/repeatString.spec.js index 1b695d4..3a33a3f 100644 --- a/repeatString/repeatString.spec.js +++ b/repeatString/repeatString.spec.js @@ -4,16 +4,16 @@ describe('repeatString', function() { it('repeats the string', function() { expect(repeatString('hey', 3)).toEqual('heyheyhey'); }); - it('repeats the string many times', function() { + xit('repeats the string many times', function() { expect(repeatString('hey', 10)).toEqual('heyheyheyheyheyheyheyheyheyhey'); }); - it('repeats the string 1 times', function() { + xit('repeats the string 1 times', function() { expect(repeatString('hey', 1)).toEqual('hey'); }); - it('repeats the string 0 times', function() { + xit('repeats the string 0 times', function() { expect(repeatString('hey', 0)).toEqual(''); }); - it('returns ERROR with negative numbers', function() { + xit('returns ERROR with negative numbers', function() { expect(repeatString('hey', -1)).toEqual('ERROR'); }); }); diff --git a/reverseString/reverseString.js b/reverseString/reverseString.js index 8c074fc..bca22be 100644 --- a/reverseString/reverseString.js +++ b/reverseString/reverseString.js @@ -1,5 +1,5 @@ -var reverseString = function(string) { - return string.split('').reverse().join('') +var reverseString = function() { + } -module.exports = reverseString +module.exports = reverseString \ No newline at end of file diff --git a/reverseString/reverseString.spec.js b/reverseString/reverseString.spec.js index 6f157e4..18887f7 100644 --- a/reverseString/reverseString.spec.js +++ b/reverseString/reverseString.spec.js @@ -5,11 +5,11 @@ describe('Hello World', function() { expect(reverseString('hello')).toEqual('olleh'); }); - it('reverses multiple words', function() { + xit('reverses multiple words', function() { expect(reverseString('hello there')).toEqual('ereht olleh') }) - it('works with numbers and punctuation', function() { + xit('works with numbers and punctuation', function() { expect(reverseString('123! abc!')).toEqual('!cba !321') }) -}); +}); \ No newline at end of file diff --git a/sumAll/sumAll.js b/sumAll/sumAll.js index 01d0116..863a79d 100644 --- a/sumAll/sumAll.js +++ b/sumAll/sumAll.js @@ -1,20 +1,5 @@ -var sumAll = function(a, b) { - if (a > b) { - let temp = a - a = b - b = temp - } - if ( - a < 0 || b < 0 || - typeof a != 'number' || typeof b != 'number' - ) { - return 'ERROR' - } - let sum = 0 - for(let i = a; i < b + 1; i++) { - sum += i - } - return sum +var sumAll = function() { + } module.exports = sumAll diff --git a/sumAll/sumAll.spec.js b/sumAll/sumAll.spec.js index 59631fa..7f48e7a 100644 --- a/sumAll/sumAll.spec.js +++ b/sumAll/sumAll.spec.js @@ -4,19 +4,19 @@ describe('sumAll', function() { it('sums numbers within the range', function() { expect(sumAll(1, 4)).toEqual(10); }); - it('works with large numbers', function() { + xit('works with large numbers', function() { expect(sumAll(1, 4000)).toEqual(8002000); }); - it('works with larger number first', function() { + xit('works with larger number first', function() { expect(sumAll(123, 1)).toEqual(7626); }); - it('returns ERROR with negative numbers', function() { + xit('returns ERROR with negative numbers', function() { expect(sumAll(-10, 4)).toEqual('ERROR'); }); - it('returns ERROR with non-number parameters', function() { + xit('returns ERROR with non-number parameters', function() { expect(sumAll(10, "90")).toEqual('ERROR'); }); - it('returns ERROR with non-number parameters', function() { + xit('returns ERROR with non-number parameters', function() { expect(sumAll(10, [90, 1])).toEqual('ERROR'); }); }); diff --git a/timer/README.md b/timer/README.md new file mode 100644 index 0000000..97ae612 --- /dev/null +++ b/timer/README.md @@ -0,0 +1,11 @@ +The goal of this exercise is for you to create a timer. The timer will operate with the following format: + +00:00:00 + +You will be given an object with the value of seconds already added. Your job is to use the class to add a string containing the timer result to this original object. + +Example: + +12 seconds given + +00:00:12 should be the output \ No newline at end of file diff --git a/timer/timer.js b/timer/timer.js new file mode 100644 index 0000000..3cd09b8 --- /dev/null +++ b/timer/timer.js @@ -0,0 +1,7 @@ +class timeFormat { + +} + +module.exports = { + timeFormat +} diff --git a/timer/timer.spec.js b/timer/timer.spec.js new file mode 100644 index 0000000..d6ce0e2 --- /dev/null +++ b/timer/timer.spec.js @@ -0,0 +1,35 @@ +var Timer = require ('./timer.js'); + +describe('Timer', function() { + var timer; // undefined, here for scope purposes + + beforeEach(function () { + timer = new Timer.timeFormat(); + }); + + it('should initialize to 0 seconds', function() { + expect(timer.seconds).toEqual(0); // makes sure timer starts with 0 seconds + }); + + describe('time_string', function() { + it('should display 0 seconds as 00:00:00', function() { + timer.seconds = 0; + expect(timer.time_string()).toEqual("00:00:00"); + }); + + it('should display 12 seconds as 00:00:12', function() { + timer.seconds = 12; + expect(timer.time_string()).toEqual("00:00:12"); + }); + + it('should display 66 seconds as 00:01:06', function() { + timer.seconds = 66; + expect(timer.time_string()).toEqual("00:01:06"); + }); + + it('should display 4000 seconds as 01:06:40', function() { + timer.seconds = 4000; + expect(timer.time_string()).toEqual("01:06:40"); + }); + }); +}); \ No newline at end of file