diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index c27de3ea1..def73e604 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 6ca0f9705..3994da7e2 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 4bcef1e45..fdbeaa169 100644 --- a/src/makeRobot.js +++ b/src/makeRobot.js @@ -30,15 +30,76 @@ * @property {number} wheels * @property {number} version * @property {function} info - * - * @param {string} name - * @param {number} wheels - * @param {number} version - * - * @return {Robot} - */ +* +* @param {string} name +* @param {number} wheels +* @param {number} version +* +* @return {Robot} +*/ function makeRobot(name, wheels, version) { - // write code here + const SERVICE_COORDINATE_X = 1400; + const SERVICE_COORDINATE_Y = 500; + + const robot = { + name, + wheels, + version, + coords: { + x: 0, + y: 0, + }, + + get info() { + return `name: ${this.name}, ` + + `chip version: ${this.version}, ` + + `wheels: ${this.wheels}`; + }, + + get location() { + return `${this.name}: x=${this.coords.x}, y=${this.coords.y}`; + }, + + goRight(step = 1) { + if (step > 0) { + this.coords.x += step; + } + + return this; + }, + + goLeft(step = 1) { + if (step > 0) { + this.coords.x -= step; + } + + return this; + }, + + goForward(step = 1) { + if (step > 0) { + this.coords.y += step; + } + + return this; + }, + + goBack(step = 1) { + if (step > 0) { + this.coords.y -= step; + } + + return this; + }, + + evacuate() { + this.coords.x = SERVICE_COORDINATE_X; + this.coords.y = SERVICE_COORDINATE_Y; + }, + + }; + + return robot; } module.exports = makeRobot;