Small Nest.js-based project
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Inga 🏳‍🌈 d585e802a2 fixed failing trivial unit tests (nest) 3 years ago
client implemented single-page application for manual testing 3 years ago
src fixed failing trivial unit tests (nest) 3 years ago
test implemented e2e test 3 years ago
.eslintrc.js created empty NestJS project 3 years ago
.gitignore created empty NestJS project 3 years ago
.prettierrc created empty NestJS project 3 years ago
LICENSE Initial commit 3 years ago
README.md added redis disclaimer for e2e tests 3 years ago
nest-cli.json configured openapi docs 3 years ago
package-lock.json enabled request validation 3 years ago
package.json enabled request validation 3 years ago
tsconfig.build.json screenshotter implemented 3 years ago
tsconfig.json connected queue to screenshotter; first functional version 3 years ago

README.md

Assignment

Datawrapper Test Project: Backend

Overview

The project is to create a web service that takes screenshots of websites.

The service should expose an API that a client can use to create a new screenshot request, with any given URL as a parameter. The web service should then return a status URL that the client can periodically call to receive updates on the status on its request. The web service should take a screenshot of the provided URL. Once the screenshot was taken, it should be possible for the client to retrieve it. The service should be designed in a scalable fashion, so that it can handle varying amounts of parallel requests in a stable and efficient fashion.

The API notation can be defined as you see fit.

Technology stack

  • Server-side code should be written in JavaScript or TypeScript
  • It should be possible to run the application locally (ideally as a containerized application, but other technologies are allowed as well)
  • Any other tools, technologies or frameworks can be used at your discretion
  • A hosted version of the application to test is a plus, but not a must

Delivery

The project should be delivered as a Github repository. It should be possible to run the service locally.

Commands

Configuration

Check .env

Installation

$ npm install

Running the app

# development
$ npm run start

# watch mode
$ npm run start:dev

# production mode
$ npm run start:prod

Test

# unit tests
$ npm run test

# e2e tests
$ npm run test:e2e

# test coverage
$ npm run test:cov

Note that you need to have redis running locally in order to run e2e tests