From 9e84b4a95fd9319d29db56f883a9f2c1ba253310 Mon Sep 17 00:00:00 2001 From: Sam Meech-Ward Date: Thu, 4 Jan 2018 09:27:38 -0800 Subject: [PATCH] Re implement traversal This branch accidentally got merged into master, so i removed all traversal and merged into master, now I'm putting it back so it can be merged back later --- test/6_vampireWithName.js | 45 +++++++++++++++++++++++++++++++++ test/7_totalDescendents.js | 42 ++++++++++++++++++++++++++++++ test/8_allMillennialVampires.js | 43 +++++++++++++++++++++++++++++++ vampire.js | 17 +++++++++++++ 4 files changed, 147 insertions(+) create mode 100644 test/6_vampireWithName.js create mode 100644 test/7_totalDescendents.js create mode 100644 test/8_allMillennialVampires.js diff --git a/test/6_vampireWithName.js b/test/6_vampireWithName.js new file mode 100644 index 0000000..f83ba47 --- /dev/null +++ b/test/6_vampireWithName.js @@ -0,0 +1,45 @@ +const chai = require('chai'); +const expect = chai.expect; + +const Vampire = require('../vampire.js'); + +describe("Vampire", function() { + + let rootVampire; + beforeEach( function() { + rootVampire = new Vampire("root"); + }); + + describe("vampireWithName", function() { + let offspring1, offspring2, offspring3, offspring4, offspring5; + beforeEach(() => { + offspring1 = new Vampire("andrew"); + offspring2 = new Vampire("sarah"); + offspring3 = new Vampire("c"); + offspring4 = new Vampire("d"); + offspring5 = new Vampire("e"); + rootVampire.addOffspring(offspring1); + offspring1.addOffspring(offspring2); + rootVampire.addOffspring(offspring3); + offspring3.addOffspring(offspring4); + offspring4.addOffspring(offspring5); + }); + + context("when searching with a name that exists in the tree", () => { + it("should return the vampire with that name", () => { + expect(rootVampire.vampireWithName(rootVampire.name).name).to.equal(rootVampire.name); + expect(rootVampire.vampireWithName(offspring1.name).name).to.equal(offspring1.name); + expect(rootVampire.vampireWithName(offspring2.name).name).to.equal(offspring2.name); + expect(rootVampire.vampireWithName(offspring5.name).name).to.equal(offspring5.name); + expect(offspring3.vampireWithName(offspring5.name).name).to.equal(offspring5.name); + }); + }); + + context("when searching with a name that does not exist in the tree", () => { + it("should return null", () => { + expect(rootVampire.vampireWithName("")).to.equal(null); + expect(offspring2.vampireWithName(offspring5.name)).to.equal(null); + }); + }); + }); +}); diff --git a/test/7_totalDescendents.js b/test/7_totalDescendents.js new file mode 100644 index 0000000..e4f1b28 --- /dev/null +++ b/test/7_totalDescendents.js @@ -0,0 +1,42 @@ +const chai = require('chai'); +const expect = chai.expect; + +const Vampire = require('../vampire.js'); + +describe("Vampire", function() { + + let rootVampire; + beforeEach( function() { + rootVampire = new Vampire("root"); + }); + + describe("totalDescendents", function() { + let offspring1, offspring2, offspring3, offspring4, offspring5, offspring6, offspring7, offspring8; + beforeEach(() => { + offspring1 = new Vampire("a"); + offspring2 = new Vampire("b"); + offspring3 = new Vampire("c"); + offspring4 = new Vampire("d"); + offspring5 = new Vampire("e"); + offspring6 = new Vampire("f"); + offspring7 = new Vampire("g"); + offspring8 = new Vampire("h"); + + rootVampire.addOffspring(offspring1); + rootVampire.addOffspring(offspring2); + rootVampire.addOffspring(offspring3); + offspring3.addOffspring(offspring4); + offspring3.addOffspring(offspring5); + offspring5.addOffspring(offspring6); + offspring6.addOffspring(offspring7); + offspring2.addOffspring(offspring8); + }); + + it("should give the total descendents underneath a specific vampire", () => { + expect(rootVampire.totalDescendents).to.equal(8); + expect(offspring1.totalDescendents).to.equal(0); + expect(offspring2.totalDescendents).to.equal(1); + expect(offspring3.totalDescendents).to.equal(4); + }); + }); +}); diff --git a/test/8_allMillennialVampires.js b/test/8_allMillennialVampires.js new file mode 100644 index 0000000..7474aa9 --- /dev/null +++ b/test/8_allMillennialVampires.js @@ -0,0 +1,43 @@ +const chai = require('chai'); +const expect = chai.expect; + +const Vampire = require('../vampire.js'); + +describe("Vampire", function() { + + let rootVampire; + beforeEach( function() { + rootVampire = new Vampire("root"); + }); + + describe("allMillennialVampires", function() { + let offspring1, offspring2, offspring3, offspring4, offspring5, offspring6, offspring7, offspring8; + beforeEach(() => { + offspring1 = new Vampire("a", 1000); + offspring2 = new Vampire("b", 900); + offspring3 = new Vampire("c", 1400); + offspring4 = new Vampire("d", 1890); + offspring5 = new Vampire("e", 1990); + offspring6 = new Vampire("f", 2000); + offspring7 = new Vampire("g", 2010); + offspring8 = new Vampire("h", 2017); + + rootVampire.addOffspring(offspring1); + rootVampire.addOffspring(offspring2); + rootVampire.addOffspring(offspring3); + offspring3.addOffspring(offspring4); + offspring3.addOffspring(offspring5); + offspring5.addOffspring(offspring6); + offspring6.addOffspring(offspring7); + offspring2.addOffspring(offspring8); + }); + + it("should return an array of all vampires converted after 1980", () => { + expect(rootVampire.allMillennialVampires.length).to.equal(4); //[offspring5, offspring6, offspring7, offspring8] + expect(rootVampire.allMillennialVampires).to.include(offspring5); + expect(rootVampire.allMillennialVampires).to.include(offspring6); + expect(rootVampire.allMillennialVampires).to.include(offspring7); + expect(rootVampire.allMillennialVampires).to.include(offspring8); + }); + }); +}); diff --git a/vampire.js b/vampire.js index 3edb57c..e75c3f2 100644 --- a/vampire.js +++ b/vampire.js @@ -28,6 +28,23 @@ class Vampire { } + /** Tree traversal methods **/ + + // Returns the vampire object with that name, or null if no vampire exists with that name + vampireWithName(name) { + + } + + // Returns the total number of vampires that exist + get totalDescendents() { + + } + + // Returns an array of all the vampires that were converted after 1980 + get allMillennialVampires() { + + } + /** Stretch **/ // Returns the closest common ancestor of two vampires.