diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index c27de3ea..def73e60 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -19,5 +19,5 @@ jobs: uses: actions/setup-node@v1 with: node-version: ${{ matrix.node-version }} - - run: npm ci + - run: npm install - run: npm test diff --git a/package.json b/package.json index 6ca0f970..3994da7e 100644 --- a/package.json +++ b/package.json @@ -16,7 +16,7 @@ "license": "GPL-3.0", "devDependencies": { "@mate-academy/eslint-config": "*", - "@mate-academy/scripts": "^0.3.1", + "@mate-academy/scripts": "^1.2.8", "eslint": "^5.16.0", "eslint-plugin-jest": "^22.4.1", "eslint-plugin-node": "^8.0.1", diff --git a/src/makeRobot.js b/src/makeRobot.js index 4bcef1e4..86db8a6e 100644 --- a/src/makeRobot.js +++ b/src/makeRobot.js @@ -38,7 +38,72 @@ * @return {Robot} */ function makeRobot(name, wheels, version) { - // write code here + const robot = { + name, + wheels, + version, + coords: { + x: 0, y: 0, + }, + + get info() { + // eslint-disable-next-line max-len + return `name: ${this.name}, chip version: ${this.version}, wheels: ${this.wheels}`; + }, + + get location() { + return `${this.name}: x=${this.coords.x}, y=${this.coords.y}`; + }, + + goForward(steps = 1) { + if (steps > 0) { + this.coords.y += steps; + } + + return this; + }, + + goBack(steps = 1) { + if (steps > 0) { + this.coords.y -= steps; + } + + return this; + }, + + goRight(steps = 1) { + if (steps > 0) { + this.coords.x += steps; + } + + return this; + }, + + goLeft(steps = 1) { + if (steps > 0) { + this.coords.x -= steps; + } + + return this; + }, + + goZero(steps) { + if (steps < 0) { + this.coords.x = 0; + this.coords.y = 0; + } + + return this; + }, + + evacuate() { + this.coords.x = 1400; + this.coords.y = 500; + }, + + }; + + return robot; } module.exports = makeRobot;