diff --git a/challenges/advanced-bonfires.json b/challenges/advanced-bonfires.json
index 1b4e7dc006..32e684830c 100644
--- a/challenges/advanced-bonfires.json
+++ b/challenges/advanced-bonfires.json
@@ -1,45 +1,205 @@
{
"name": "Advanced Algorithm Scripting",
- "order": 0.011,
+ "order": 0.013,
"challenges": [
{
- "id": "a2f1d72d9b908d0bd72bb9f6",
- "title": "Make a Person",
- "difficulty": "3.01",
+ "id": "aff0395860f5d3034dc0bfc9",
+ "title": "Validate US Telephone Numbers",
+ "type": "bonfire",
+ "difficulty": "4.01",
"description": [
- "Fill in the object constructor with the methods specified in the tests.",
- "Those methods are getFirstName(), getLastName(), getFullName(), setFirstName(first), setLastName(last), and setFullName(firstAndLast).",
- "All functions that take an argument have an arity of 1, and the argument will be a string.",
- "These methods must be the only available means for interacting with the object.",
+ "Return true if the passed string is a valid US phone number",
+ "The user may fill out the form field any way they choose as long as it is a valid US number. The following are all valid formats for US numbers:",
+ "555-555-5555, (555)555-5555, (555) 555-5555, 555 555 5555, 5555555555, 1 555 555 5555",
+ "For this challenge you will be presented with a string such as \"800-692-7753\" or \"8oo-six427676;laskdjf\". Your job is to validate or reject the US phone number based on any combination of the formats provided above. The area code is required. If the country code is provided, you must confirm that the country code is \"1\". Return true if the string is a valid US phone number; otherwise false.",
+ "Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
+ ],
+ "tests": [
+ "expect(telephoneCheck(\"555-555-5555\")).to.be.a(\"boolean\");",
+ "assert.deepEqual(telephoneCheck(\"1 555-555-5555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"1 (555) 555-5555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"5555555555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"555-555-5555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"(555)555-5555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"1(555)555-5555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"1 555 555 5555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"555-555-5555\"), true);",
+ "assert.deepEqual(telephoneCheck(\"1 456 789 4444\"), true);",
+ "assert.deepEqual(telephoneCheck(\"123**&!!asdf#\"), false);",
+ "assert.deepEqual(telephoneCheck(\"55555555\"), false);",
+ "assert.deepEqual(telephoneCheck(\"(6505552368)\"), false);",
+ "assert.deepEqual(telephoneCheck(\"2 (757) 622-7382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"0 (757) 622-7382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"-1 (757) 622-7382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"2 757 622-7382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"10 (757) 622-7382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"27576227382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"(275)76227382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"2(757)6227382\"), false);",
+ "assert.deepEqual(telephoneCheck(\"2(757)622-7382\"), false);"
+ ],
+ "challengeSeed": [
+ "function telephoneCheck(str) {",
+ " // Good luck!",
+ " return true;",
+ "}",
+ "",
+ "",
+ "",
+ "telephoneCheck(\"555-555-5555\");"
+ ],
+ "MDNlinks": [
+ "RegExp"
+ ],
+ "challengeType": 5,
+ "nameCn": "",
+ "descriptionCn": [],
+ "nameFr": "",
+ "descriptionFr": [],
+ "nameRu": "",
+ "descriptionRu": [],
+ "nameEs": "",
+ "descriptionEs": [],
+ "namePt": "",
+ "descriptionPt": []
+ },
+ {
+ "id": "a3f503de51cf954ede28891d",
+ "name": "Bonfire: Symmetric Difference",
+ "dashedName": "bonfire-symmetric-difference",
+ "difficulty": "4.02",
+ "description": [
+ "Create a function that takes two or more arrays and returns an array of the symmetric difference of the provided arrays.",
+ "The mathematical term symmetric difference refers to the elements in two sets that are in either the first or second set, but not in both.",
"Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
],
"challengeSeed": [
- "var Person = function(firstAndLast) {",
- " return firstAndLast;",
- "};",
+ "function sym(args) {",
+ " return arguments;",
+ "}",
"",
- "var bob = new Person('Bob Ross');",
- "bob.getFullName();"
+ "sym([1, 2, 3], [5, 2, 1, 4]);"
],
"tests": [
- "expect(Object.keys(bob).length).to.eql(6);",
- "expect(bob instanceof Person).to.be.true;",
- "expect(bob.firstName).to.be.undefined();",
- "expect(bob.lastName).to.be.undefined();",
- "expect(bob.getFirstName()).to.eql('Bob');",
- "expect(bob.getLastName()).to.eql('Ross');",
- "expect(bob.getFullName()).to.eql('Bob Ross');",
- "bob.setFirstName('Happy');",
- "expect(bob.getFirstName()).to.eql('Happy');",
- "bob.setLastName('Trees');",
- "expect(bob.getLastName()).to.eql('Trees');",
- "bob.setFullName('George Carlin');",
- "expect(bob.getFullName()).to.eql('George Carlin');",
- "bob.setFullName('Bob Ross');"
+ "expect(sym([1, 2, 3], [5, 2, 1, 4])).to.equal([3, 5, 4]);",
+ "assert.deepEqual(sym([1, 2, 5], [2, 3, 5], [3, 4, 5]), [1, 4, 5], 'should return the symmetric difference of the given arrays');",
+ "assert.deepEqual(sym([1, 1, 2, 5], [2, 2, 3, 5], [3, 4, 5, 5]), [1, 4, 5], 'should return an array of unique values');",
+ "assert.deepEqual(sym([1, 1]), [1], 'should return an array of unique values');"
],
"MDNlinks": [
- "Closures",
- "Details of the Object Model"
+ "Array.reduce()",
+ "Symmetric Difference"
+ ],
+ "challengeType": 5,
+ "nameCn": "",
+ "descriptionCn": [],
+ "nameFr": "",
+ "descriptionFr": [],
+ "nameRu": "",
+ "descriptionRu": [],
+ "nameEs": "",
+ "descriptionEs": [],
+ "namePt": "",
+ "descriptionPt": []
+ },
+ {
+ "id": "aa2e6f85cab2ab736c9a9b24",
+ "name": "Bonfire: Exact Change",
+ "dashedName": "bonfire-exact-change",
+ "difficulty": "4.03",
+ "description": [
+ "Design a cash register drawer function that accepts purchase price as the first argument, payment as the second argument, and cash-in-drawer (cid) as the third argument.",
+ "cid is a 2d array listing available currency.",
+ "Return the string \"Insufficient Funds\" if cash-in-drawer is less than the change due. Return the string \"Closed\" if cash-in-drawer is equal to the change due.",
+ "Otherwise, return change in coin and bills, sorted in highest to lowest order.",
+ "Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
+ ],
+ "challengeSeed": [
+ "function drawer(price, cash, cid) {",
+ " var change;",
+ " // Here is your change, ma'am.",
+ " return change;",
+ "}",
+ "",
+ "// Example cash-in-drawer array:",
+ "// [['PENNY', 1.01],",
+ "// ['NICKEL', 2.05],",
+ "// ['DIME', 3.10],",
+ "// ['QUARTER', 4.25],",
+ "// ['ONE', 90.00],",
+ "// ['FIVE', 55.00],",
+ "// ['TEN', 20.00],",
+ "// ['TWENTY', 60.00],",
+ "// ['ONE HUNDRED', 100.00]]",
+ "",
+ "drawer(19.50, 20.00, [['PENNY', 1.01], ['NICKEL', 2.05], ['DIME', 3.10], ['QUARTER', 4.25], ['ONE', 90.00], ['FIVE', 55.00], ['TEN', 20.00], ['TWENTY', 60.00], ['ONE HUNDRED', 100.00]]);"
+ ],
+ "tests": [
+ "expect(drawer(19.50, 20.00, [['PENNY', 1.01], ['NICKEL', 2.05], ['DIME', 3.10], ['QUARTER', 4.25], ['ONE', 90.00], ['FIVE', 55.00], ['TEN', 20.00], ['TWENTY', 60.00], ['ONE HUNDRED', 100.00]])).to.be.a('array');",
+ "expect(drawer(19.50, 20.00, [['PENNY', 0.01], ['NICKEL', 0], ['DIME', 0], ['QUARTER', 0], ['ONE', 0], ['FIVE', 0], ['TEN', 0], ['TWENTY', 0], ['ONE HUNDRED', 0]])).to.be.a('string');",
+ "expect(drawer(19.50, 20.00, [['PENNY', 0.50], ['NICKEL', 0], ['DIME', 0], ['QUARTER', 0], ['ONE', 0], ['FIVE', 0], ['TEN', 0], ['TWENTY', 0], ['ONE HUNDRED', 0]])).to.be.a('string');",
+ "assert.deepEqual(drawer(19.50, 20.00, [['PENNY', 1.01], ['NICKEL', 2.05], ['DIME', 3.10], ['QUARTER', 4.25], ['ONE', 90.00], ['FIVE', 55.00], ['TEN', 20.00], ['TWENTY', 60.00], ['ONE HUNDRED', 100.00]]), [['QUARTER', 0.50]], 'return correct change');",
+ "assert.deepEqual(drawer(3.26, 100.00, [['PENNY', 1.01], ['NICKEL', 2.05], ['DIME', 3.10], ['QUARTER', 4.25], ['ONE', 90.00], ['FIVE', 55.00], ['TEN', 20.00], ['TWENTY', 60.00], ['ONE HUNDRED', 100.00]]), [['TWENTY', 60.00], ['TEN', 20.00], ['FIVE', 15], ['ONE', 1], ['QUARTER', 0.50], ['DIME', 0.20], ['PENNY', 0.04] ], 'return correct change with multiple coins and bills');",
+ "assert.deepEqual(drawer(19.50, 20.00, [['PENNY', 0.01], ['NICKEL', 0], ['DIME', 0], ['QUARTER', 0], ['ONE', 0], ['FIVE', 0], ['TEN', 0], ['TWENTY', 0], ['ONE HUNDRED', 0]]), 'Insufficient Funds', 'insufficient funds');",
+ "assert.deepEqual(drawer(19.50, 20.00, [['PENNY', 0.50], ['NICKEL', 0], ['DIME', 0], ['QUARTER', 0], ['ONE', 0], ['FIVE', 0], ['TEN', 0], ['TWENTY', 0], ['ONE HUNDRED', 0]]), \"Closed\", 'cash-in-drawer equals change');"
+ ],
+ "MDNlinks": [
+ "Global Object"
+ ],
+ "challengeType": 5,
+ "nameCn": "",
+ "descriptionCn": [],
+ "nameFr": "",
+ "descriptionFr": [],
+ "nameRu": "",
+ "descriptionRu": [],
+ "nameEs": "",
+ "descriptionEs": [],
+ "namePt": "",
+ "descriptionPt": []
+ },
+ {
+ "id": "a56138aff60341a09ed6c480",
+ "name": "Bonfire: Inventory Update",
+ "dashedName": "bonfire-inventory-update",
+ "difficulty": "4.04",
+ "description": [
+ "Compare and update inventory stored in a 2d array against a second 2d array of a fresh delivery. Update current inventory item quantity, and if an item cannot be found, add the new item and quantity into the inventory array in alphabetical order.",
+ "Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
+ ],
+ "challengeSeed": [
+ "function inventory(arr1, arr2) {",
+ " // All inventory must be accounted for or you're fired!",
+ " return arr1;",
+ "}",
+ "",
+ "// Example inventory lists",
+ "var curInv = [",
+ " [21, 'Bowling Ball'],",
+ " [2, 'Dirty Sock'],",
+ " [1, 'Hair Pin'],",
+ " [5, 'Microphone']",
+ "];",
+ "",
+ "var newInv = [",
+ " [2, 'Hair Pin'],",
+ " [3, 'Half-Eaten Apple'],",
+ " [67, 'Bowling Ball'],",
+ " [7, 'Toothpaste']",
+ "];",
+ "",
+ "inventory(curInv, newInv);"
+ ],
+ "tests": [
+ "expect(inventory([[21, 'Bowling Ball'], [2, 'Dirty Sock'], [1, 'Hair Pin'], [5, 'Microphone']], [[2, 'Hair Pin'], [3, 'Half-Eaten Apple'], [67, 'Bowling Ball'], [7, 'Toothpaste']])).to.be.a('array');",
+ "assert.equal(inventory([[21, 'Bowling Ball'], [2, 'Dirty Sock'], [1, 'Hair Pin'], [5, 'Microphone']], [[2, 'Hair Pin'], [3, 'Half-Eaten Apple'], [67, 'Bowling Ball'], [7, 'Toothpaste']]).length, 6);",
+ "assert.deepEqual(inventory([[21, 'Bowling Ball'], [2, 'Dirty Sock'], [1, 'Hair Pin'], [5, 'Microphone']], [[2, 'Hair Pin'], [3, 'Half-Eaten Apple'], [67, 'Bowling Ball'], [7, 'Toothpaste']]), [[88, 'Bowling Ball'], [2, 'Dirty Sock'], [3, 'Hair Pin'], [3, 'Half-Eaten Apple'], [5, 'Microphone'], [7, 'Toothpaste']]);",
+ "assert.deepEqual(inventory([[21, 'Bowling Ball'], [2, 'Dirty Sock'], [1, 'Hair Pin'], [5, 'Microphone']], []), [[21, 'Bowling Ball'], [2, 'Dirty Sock'], [1, 'Hair Pin'], [5, 'Microphone']]);",
+ "assert.deepEqual(inventory([], [[2, 'Hair Pin'], [3, 'Half-Eaten Apple'], [67, 'Bowling Ball'], [7, 'Toothpaste']]), [[67, 'Bowling Ball'], [2, 'Hair Pin'], [3, 'Half-Eaten Apple'], [7, 'Toothpaste']]);",
+ "assert.deepEqual(inventory([[0, 'Bowling Ball'], [0, 'Dirty Sock'], [0, 'Hair Pin'], [0, 'Microphone']], [[1, 'Hair Pin'], [1, 'Half-Eaten Apple'], [1, 'Bowling Ball'], [1, 'Toothpaste']]), [[1, 'Bowling Ball'], [0, 'Dirty Sock'], [1, 'Hair Pin'], [1, 'Half-Eaten Apple'], [0, 'Microphone'], [1, 'Toothpaste']]);"
+ ],
+ "MDNlinks": [
+ "Global Array Object"
],
"type": "bonfire",
"challengeType": 5,
@@ -55,32 +215,33 @@
"descriptionPt": []
},
{
- "id": "af4afb223120f7348cdfc9fd",
- "title": "Map the Debris",
- "difficulty": "3.02",
+ "id": "a7bf700cd123b9a54eef01d5",
+ "title": "No repeats please",
+ "difficulty": "4.05",
"description": [
- "Return a new array that transforms the element's average altitude into their orbital periods.",
- "The array will contain objects in the format {name: 'name', avgAlt: avgAlt}
.",
- "You can read about orbital periods on wikipedia.",
- "The values should be rounded to the nearest whole number. The body being orbited is Earth.",
- "The radius of the earth is 6367.4447 kilometers, and the GM value of earth is 398600.4418",
+ "Return the number of total permutations of the provided string that don't have repeated consecutive letters.",
+ "For example, 'aab' should return 2 because it has 6 total permutations, but only 2 of them don't have the same letter (in this case 'a') repeating.",
"Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
],
"challengeSeed": [
- "function orbitalPeriod(arr) {",
- " var GM = 398600.4418;",
- " var earthRadius = 6367.4447;",
- " return arr;",
+ "function permAlone(str) {",
+ " return str;",
"}",
"",
- "orbitalPeriod([{name : \"sputnik\", avgAlt : 35873.5553}]);"
+ "permAlone('aab');"
],
"tests": [
- "expect(orbitalPeriod([{name : \"sputnik\", avgAlt : 35873.5553}])).to.eqls([{name: \"sputnik\", orbitalPeriod: 86400}]);",
- "expect(orbitalPeriod([{name: \"iss\", avgAlt: 413.6}, {name: \"hubble\", avgAlt: 556.7}, {name: \"moon\", avgAlt: 378632.553}])).to.eqls([{name : \"iss\", orbitalPeriod: 5557}, {name: \"hubble\", orbitalPeriod: 5734}, {name: \"moon\", orbitalPeriod: 2377399}]);"
+ "expect(permAlone('aab')).to.be.a('number');",
+ "expect(permAlone('aab')).to.equal(2);",
+ "expect(permAlone('aaa')).to.equal(0);",
+ "expect(permAlone('aabb')).to.equal(8);",
+ "expect(permAlone('abcdefa')).to.equal(3600);",
+ "expect(permAlone('abfdefa')).to.equal(2640);",
+ "expect(permAlone('zzzzzzzz')).to.equal(0);"
],
"MDNlinks": [
- "Math.pow()"
+ "Permutations",
+ "RegExp"
],
"type": "bonfire",
"challengeType": 5,
@@ -96,31 +257,37 @@
"descriptionPt": []
},
{
- "id": "a3f503de51cfab748ff001aa",
- "title": "Pairwise",
- "difficulty": "3.03",
+ "id": "a19f0fbe1872186acd434d5a",
+ "title": "Friendly Date Ranges",
+ "dashedName": "bonfire-friendly-date-ranges",
+ "difficulty": "4.06",
"description": [
- "Return the sum of all indices of elements of 'arr' that can be paired with one other element to form a sum that equals the value in the second argument 'arg'. If multiple sums are possible, return the smallest sum. Once an element has been used, it cannot be reused to pair with another.",
- "For example, pairwise([1, 4, 2, 3, 0, 5], 7) should return 11 because 4, 2, 3 and 5 can be paired with each other to equal 7.",
- "pairwise([1, 3, 2, 4], 4) would only equal 1, because only the first two elements can be paired to equal 4, and the first element has an index of 0!",
+ "Implement a way of converting two dates into a more friendly date range that could be presented to a user.",
+ "It must not show any redundant information in the date range.",
+ "For example, if the year and month are the same then only the day range should be displayed.",
+ "Secondly, if the starting year is the current year, and the ending year can be inferred by the reader, the year should be omitted.",
+ "Input date is formatted as YYYY-MM-DD",
"Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
],
"challengeSeed": [
- "function pairwise(arr, arg) {",
- " return arg;",
+ "function friendly(str) {",
+ " return str;",
"}",
"",
- "pairwise([1,4,2,3,0,5], 7);"
+ "friendly(['2015-07-01', '2015-07-04']);"
],
"tests": [
- "expect(pairwise([1, 4, 2, 3, 0, 5], 7)).to.equal(11);",
- "expect(pairwise([1, 3, 2, 4], 4)).to.equal(1);",
- "expect(pairwise([1,1,1], 2)).to.equal(1);",
- "expect(pairwise([0, 0, 0, 0, 1, 1], 1)).to.equal(10);",
- "expect(pairwise([], 100)).to.equal(0);"
+ "assert.deepEqual(friendly(['2015-07-01', '2015-07-04']), ['July 1st','4th'], 'ending month should be omitted since it is already mentioned');",
+ "assert.deepEqual(friendly(['2015-12-01', '2016-02-03']), ['December 1st','February 3rd'], 'two months apart can be inferred if it is the next year');",
+ "assert.deepEqual(friendly(['2015-12-01', '2017-02-03']), ['December 1st, 2015','February 3rd, 2017']);",
+ "assert.deepEqual(friendly(['2016-03-01', '2016-05-05']), ['March 1st','May 5th'], 'one month apart can be inferred it is the same year');",
+ "assert.deepEqual(friendly(['2017-01-01', '2017-01-01']), ['January 1st, 2017'], 'since we do not duplicate only return once');",
+ "assert.deepEqual(friendly(['2022-09-05', '2023-09-04']), ['September 5th, 2022','September 4th, 2023']);"
],
"MDNlinks": [
- "Array.reduce()"
+ "String.split()",
+ "String.substr()",
+ "parseInt()"
],
"type": "bonfire",
"challengeType": 5,
diff --git a/challenges/basic-javascript.json b/challenges/basic-javascript.json
index 1fa0d2cd85..888782e4b6 100644
--- a/challenges/basic-javascript.json
+++ b/challenges/basic-javascript.json
@@ -270,9 +270,9 @@
"title": "Add Two Numbers with JavaScript",
"difficulty": "9.98141",
"description": [
- "In JavaScript whole numbers (called integers) can be easily used to preform mathematical functions",
- "Let's try a few of the most commonly used ones now",
- "We use +
for addition",
+ "In JavaScript whole numbers (called integers) can be easily used to perform mathematical functions.",
+ "Let's try a few of the most commonly used ones now.",
+ "We use +
for addition.",
"Replace the 0
with correct number to achieve the result in the comment."
],
"tests": [
@@ -293,9 +293,9 @@
"title": "Subtract One Number from Another with JavaScript",
"difficulty": "9.98142",
"description": [
- "In JavaScript whole numbers (called integers) can be easily used to preform mathematical functions",
- "Let's try a few of the most commonly used ones now",
- "We use -
for subtraction",
+ "In JavaScript whole numbers (called integers) can be easily used to perform mathematical functions.",
+ "Let's try a few of the most commonly used ones now.",
+ "We use -
for subtraction.",
"Replace the 0
with correct number to achieve the result in the comment."
],
"tests": [
@@ -316,9 +316,9 @@
"title": "Multiply Two Numbers with JavaScript",
"difficulty": "9.98143",
"description": [
- "In JavaScript whole numbers (called integers) can be easily used to preform mathematical functions",
- "Let's try a few of the most commonly used ones now",
- "We use *
for multiplication",
+ "In JavaScript whole numbers (called integers) can be easily used to perform mathematical functions.",
+ "Let's try a few of the most commonly used ones now.",
+ "We use *
for multiplication.",
"Replace the 0
with correct number to achieve the result in the comment."
],
"tests": [
@@ -339,9 +339,9 @@
"title": "Divide One Number by Another with JavaScript",
"difficulty": "9.9814",
"description": [
- "In JavaScript whole numbers (called integers) can be easily used to preform mathematical functions",
- "Let's try a few of the most commonly used ones now",
- "We use /
for division",
+ "In JavaScript whole numbers (called integers) can be easily used to perform mathematical functions.",
+ "Let's try a few of the most commonly used ones now.",
+ "We use /
for division.",
"Replace the 0
with correct number to achieve the result in the comment."
],
"tests": [
@@ -362,7 +362,7 @@
"title": "Create Decimal Numbers with JavaScript",
"difficulty": "9.9815",
"description": [
- "in JavaScript we can can work with decimal numbers",
+ "In JavaScript we can can work with decimal numbers.",
"Let's create a variable myDecimal
and give it a decimal value."
],
"tests": [
diff --git a/challenges/bootstrap.json b/challenges/bootstrap.json
index 4efee80099..7a6ad78bcc 100644
--- a/challenges/bootstrap.json
+++ b/challenges/bootstrap.json
@@ -1432,9 +1432,9 @@
"This is the last challenge we'll do for our Cat Photo App for now. We hope you've enjoyed learning Font Awesome, Bootstrap, and responsive design!"
],
"tests": [
- "assert($('div.row:has(input[type=\\'text\\'])').length > 0 && $('div.row:has(button[type=\\'submit\\'])').length > 0, 'Nest your form submission button and text area in a div with class \"row\".')",
+ "assert($('div.row:has(input[type=\\'text\\'])').length > 0 && $('div.row:has(button[type=\\'submit\\'])').length > 0, 'Nest your form submission button and text input in a div with class \"row\".')",
"assert($('div.col-xs-5:has(button[type=\\'submit\\'])').length > 0, 'Nest your form submission button in a div with the class \"col-xs-5\".')",
- "assert($('div.col-xs-7:has(input[type=\\'text\\'])').length > 0, 'Nest your form text area in a div with the class \"col-xs-7\".')",
+ "assert($('div.col-xs-7:has(input[type=\\'text\\'])').length > 0, 'Nest your form text input in a div with the class \"col-xs-7\".')",
"assert(editor.match(/<\\/div>/g) && editor.match(/
scope-chains-closures
with this command: npm install -g scope-chains-closures
",
- "Now start the tutorial by running scope-chains-closures
.",
- "Note that you can resize the c9.io's windows by dragging their borders.",
- "Make sure that you are always in your project's \"workspace\" directory. You can always navigate back to this directory by running this command: cd ~/workspace
.",
- "You can view this Node School module's source code on GitHub at https://github.com/jesstelford/scope-chains-closures.",
- "Complete \"Scopes\"",
- "Complete \"Scope Chains\"",
- "Complete \"Global Scope and Shadowing\"",
- "Complete \"Closures\"",
- "Complete \"Garbage Collection\"",
- "Once you've completed these steps, move on to our next challenge."
- ],
- "type": "waypoint",
- "challengeType": 2,
- "tests": [],
- "nameCn": "",
- "descriptionCn": [],
- "nameFr": "",
- "descriptionFr": [],
- "nameRu": "",
- "descriptionRu": [],
- "nameEs": "",
- "descriptionEs": [],
- "namePt": "",
- "descriptionPt": []
- },
- {
- "id": "bd7153d8b44eeddfaeb5bd0f",
- "title": "Use Prototypes for Inheriting Properties",
- "difficulty": 0.02,
- "challengeSeed": ["133316036"],
- "description": [
- "We'll build this Waypoint on Cloud 9, a powerful online code editor with a full Ubuntu Linux workspace, all running in the cloud.",
- "If you don't already have Cloud 9 account, create one now at http://c9.io.",
- "Open up http://c9.io and sign in to your account.",
- "Click on Create New Workspace at the top right of the c9.io page, then click on the \"Create a new workspace\" popup that appears below it the button after you click on it.",
- "Give your workspace a name.",
- "Choose Node.js in the selection area below the name field.",
- "Click the Create button. Then click into your new workspace.",
- "In the lower right hand corner you should see a terminal window. In this window use the following commands. You don't need to know what these mean at this point.",
- "Install planetproto
with this command: npm install -g planetproto
",
- "Now start the tutorial by running planetproto
.",
- "Note that you can resize the c9.io's windows by dragging their borders.",
- "Make sure that you are always in your project's \"workspace\" directory. You can always navigate back to this directory by running this command: cd ~/workspace
.",
- "You can view this Node School module's source code on GitHub at https://github.com/sporto/planetproto.",
- "Complete \"Simple Objects\"",
- "Complete \"Proto\"",
- "Complete \"Dynamic Lookups\"",
- "Complete \"Property Assignments\"",
- "Complete \"Arrays and Objects\"",
- "Complete \"Object Create\"",
- "Complete \"Dot New\"",
- "Complete \"Constructor Functions\"",
- "Complete \"Implicit This\"",
- "Note that you can skip the last challenge.",
- "Once you've completed these steps, move on to our next challenge."
- ],
- "type": "waypoint",
- "challengeType": 2,
- "tests": [],
- "nameCn": "",
- "descriptionCn": [],
- "nameFr": "",
- "descriptionFr": [],
- "nameRu": "",
- "descriptionRu": [],
- "nameEs": "",
- "descriptionEs": [],
- "namePt": "",
- "descriptionPt": []
- },
- {
- "id": "bd7129d8c441eddfbeb5bddf",
- "title": "Practice Functional Programming",
- "difficulty": 0.01,
- "challengeSeed": ["129169463"],
- "description": [
- "Functional programming holds the key to unlocking JavaScript's powerful asynchronous features.",
- "Jafar Husain's interactive Functional Programming course will familiarize you with the various ways you can recombine these functions.",
- "Functional programming in JavaScript involves using five key functions: \"map\", \"reduce\", \"filter\", \"concatAll\", and \"zip\".",
- "Click here to go to the challenge: http://jhusain.github.io/learnrx/.",
- "You only need to complete the first 27 steps of this tutorial.",
- "This challenge will take several hours, but don't worry. Jafar's website will save your progress (using your browser's local storage) so you don't need to finish it in one sitting.",
- "If you've spent several minutes on one of these challenges, and still can't figure out its correct answer, you can click \"show answer\", then click \"run\" to advance to the next challenge. Be sure to read the correct answer and make sure you understand it before moving on."
- ],
- "type": "waypoint",
- "challengeType": 2,
- "tests": [],
- "nameCn": "",
- "descriptionCn": [],
- "nameFr": "",
- "descriptionFr": [],
- "nameRu": "",
- "descriptionRu": [],
- "nameEs": "",
- "descriptionEs": [],
- "namePt": "",
- "descriptionPt": []
- }
]
}
diff --git a/challenges/upper-intermediate-bonfires.json b/challenges/upper-intermediate-bonfires.json
new file mode 100644
index 0000000000..bfd765facb
--- /dev/null
+++ b/challenges/upper-intermediate-bonfires.json
@@ -0,0 +1,139 @@
+{
+ "name": "Upper Intermediate Algorithm Scripting",
+ "order": 0.011,
+ "challenges": [
+ {
+ "id": "a2f1d72d9b908d0bd72bb9f6",
+ "name": "Bonfire: Make a Person",
+ "dashedName": "bonfire-make-a-person",
+ "difficulty": "3.01",
+ "description": [
+ "Fill in the object constructor with the methods specified in the tests.",
+ "Those methods are getFirstName(), getLastName(), getFullName(), setFirstName(first), setLastName(last), and setFullName(firstAndLast).",
+ "All functions that take an argument have an arity of 1, and the argument will be a string.",
+ "These methods must be the only available means for interacting with the object.",
+ "Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
+ ],
+ "challengeSeed": [
+ "var Person = function(firstAndLast) {",
+ " return firstAndLast;",
+ "};",
+ "",
+ "var bob = new Person('Bob Ross');",
+ "bob.getFullName();"
+ ],
+ "tests": [
+ "expect(Object.keys(bob).length).to.eql(6);",
+ "expect(bob instanceof Person).to.be.true;",
+ "expect(bob.firstName).to.be.undefined();",
+ "expect(bob.lastName).to.be.undefined();",
+ "expect(bob.getFirstName()).to.eql('Bob');",
+ "expect(bob.getLastName()).to.eql('Ross');",
+ "expect(bob.getFullName()).to.eql('Bob Ross');",
+ "bob.setFirstName('Happy');",
+ "expect(bob.getFirstName()).to.eql('Happy');",
+ "bob.setLastName('Trees');",
+ "expect(bob.getLastName()).to.eql('Trees');",
+ "bob.setFullName('George Carlin');",
+ "expect(bob.getFullName()).to.eql('George Carlin');",
+ "bob.setFullName('Bob Ross');"
+ ],
+ "MDNlinks": [
+ "Closures",
+ "Details of the Object Model"
+ ],
+ "challengeType": 5,
+ "nameCn": "",
+ "descriptionCn": [],
+ "nameFr": "",
+ "descriptionFr": [],
+ "nameRu": "",
+ "descriptionRu": [],
+ "nameEs": "",
+ "descriptionEs": [],
+ "namePt": "",
+ "descriptionPt": []
+ },
+ {
+ "id": "af4afb223120f7348cdfc9fd",
+ "name": "Bonfire: Map the Debris",
+ "dashedName": "bonfire-map-the-debris",
+ "difficulty": "3.02",
+ "description": [
+ "Return a new array that transforms the element's average altitude into their orbital periods.",
+ "The array will contain objects in the format {name: 'name', avgAlt: avgAlt}
.",
+ "You can read about orbital periods on wikipedia.",
+ "The values should be rounded to the nearest whole number. The body being orbited is Earth.",
+ "The radius of the earth is 6367.4447 kilometers, and the GM value of earth is 398600.4418",
+ "Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
+ ],
+ "challengeSeed": [
+ "function orbitalPeriod(arr) {",
+ " var GM = 398600.4418;",
+ " var earthRadius = 6367.4447;",
+ " return arr;",
+ "}",
+ "",
+ "orbitalPeriod([{name : \"sputnik\", avgAlt : 35873.5553}]);"
+ ],
+ "tests": [
+ "expect(orbitalPeriod([{name : \"sputnik\", avgAlt : 35873.5553}])).to.eqls([{name: \"sputnik\", orbitalPeriod: 86400}]);",
+ "expect(orbitalPeriod([{name: \"iss\", avgAlt: 413.6}, {name: \"hubble\", avgAlt: 556.7}, {name: \"moon\", avgAlt: 378632.553}])).to.eqls([{name : \"iss\", orbitalPeriod: 5557}, {name: \"hubble\", orbitalPeriod: 5734}, {name: \"moon\", orbitalPeriod: 2377399}]);"
+ ],
+ "MDNlinks": [
+ "Math.pow()"
+ ],
+ "challengeType": 5,
+ "nameCn": "",
+ "descriptionCn": [],
+ "nameFr": "",
+ "descriptionFr": [],
+ "nameRu": "",
+ "descriptionRu": [],
+ "nameEs": "",
+ "descriptionEs": [],
+ "namePt": "",
+ "descriptionPt": []
+ },
+ {
+ "id": "a3f503de51cfab748ff001aa",
+ "name": "Bonfire: Pairwise",
+ "dashedName": "bonfire-pairwise",
+ "difficulty": "3.03",
+ "description": [
+ "Return the sum of all indices of elements of 'arr' that can be paired with one other element to form a sum that equals the value in the second argument 'arg'. If multiple sums are possible, return the smallest sum. Once an element has been used, it cannot be reused to pair with another.",
+ "For example, pairwise([1, 4, 2, 3, 0, 5], 7) should return 11 because 4, 2, 3 and 5 can be paired with each other to equal 7.",
+ "pairwise([1, 3, 2, 4], 4) would only equal 1, because only the first two elements can be paired to equal 4, and the first element has an index of 0!",
+ "Remember to use RSAP if you get stuck. Try to pair program. Write your own code."
+ ],
+ "challengeSeed": [
+ "function pairwise(arr, arg) {",
+ " return arg;",
+ "}",
+ "",
+ "pairwise([1,4,2,3,0,5], 7);"
+ ],
+ "tests": [
+ "expect(pairwise([1, 4, 2, 3, 0, 5], 7)).to.equal(11);",
+ "expect(pairwise([1, 3, 2, 4], 4)).to.equal(1);",
+ "expect(pairwise([1,1,1], 2)).to.equal(1);",
+ "expect(pairwise([0, 0, 0, 0, 1, 1], 1)).to.equal(10);",
+ "expect(pairwise([], 100)).to.equal(0);"
+ ],
+ "MDNlinks": [
+ "Array.reduce()"
+ ],
+ "challengeType": 5,
+ "nameCn": "",
+ "descriptionCn": [],
+ "nameFr": "",
+ "descriptionFr": [],
+ "nameRu": "",
+ "descriptionRu": [],
+ "nameEs": "",
+ "descriptionEs": [],
+ "namePt": "",
+ "descriptionPt": []
+ }
+ ]
+}