data:image/s3,"s3://crabby-images/f2fdd/f2fddbe386333910c6fe90cc252a532b370870b4" alt=""
Teste Técnico Frontend
Sitepoint
SitePoint é uma das maiores comunidades online de profissionais da web
Sobre o Teste
Neste desafio, você precisa criar um aplicativo de contador simples que permita adicionar um contador com nome a uma lista, incrementar ou decrementar qualquer contador, excluir um contador e exibir a soma de todos os valores dos contadores. Os dados devem ser persistidos no servidor. As tecnologias sugeridas incluem HTML, CSS e JavaScript para a criação da interface do usuário, Node.js e Express.js para a criação do servidor, Axios ou Fetch API para fazer requisições HTTP para o servidor, JSON para a comunicação entre o cliente e o servidor, e Git para controle de versão. Você pode escolher outras tecnologias de sua preferência, desde que atendam aos requisitos do projeto.
Instruções do Teste
SITEPOINT FRONTEND TEST
You need to create a simple counter application that can do the following:
- Add a named counter to a list of counters
- Increment any of the counters
- Decrement any of the counters
- Delete a counter
- Show a sum of all the counter values
- It must persist data back to the server
We have provided:
- Compiled Directory: of
/static/
/static/index.html
that will be served atlocalhost:3000
when the server is running/static/app.js
and/static/app.css
will be used automatically by/static/index.html
If you need other publicly available files, other than
index.html
,app.js
,app.css
you will have to modify the server code in/index.js
Some other notes:
- The design, layout, ux, is all up to you.
- You can change anything you want (server stuff included) as long as the above list is completed.
- This isn't a backend test, don't make it require any databases.
- If you decide to use a precompiler of any kind (js/css/etc..) we need to be able to run it with
npm run build
. - We don't want to run any
npm install -g whatever
commands. NO GLOBAL DEPENDENCIES - Tests are good.
A possible layout could be:
Counter App
+-----------------------------+
| Input [+] |
+-----------------------------+
+-----------------------------+
| [x] Bob [-] 5 [+] |
| [x] Steve [-] 1 [+] |
| [x] Pat [-] 4 [+] |
+-----------------------------+
+-----------------------------+
| Total 10 |
+-----------------------------+
Install and start the server
$ npm install$ npm start$ npm run build #[optional] use for any precompilers you choose
API endpoints / examples
The following endpoints are expecting a
Content-Type: application/json
GET /api/v1/counters# []POST {title: "bob"} /api/v1/counter# [# {id: "asdf", title: "bob", count: 0}# ]POST {title: "steve"} /api/v1/counter# [# {id: "asdf", title: "bob", count: 0},# {id: "qwer", title: "steve", count: 0}# ]POST {id: "asdf"} /api/v1/counter/inc# [# {id: "asdf", title: "bob", count: 1},# {id: "qwer", title: "steve", count: 0}# ]POST {id: "qwer"} /api/v1/counter/dec# [# {id: "asdf", title: "bob", count: 1},# {id: "qwer", title: "steve", count: -1}# ]DELETE {id: "qwer"} /api/v1/counter# [# {id: "asdf", title: "bob", count: 1}# ]GET /api/v1/counters# [# {id: "asdf", title: "bob", count: 1},# ]
*NOTE: Each request returns the current state of all counters.