Skip to content

bbffbb/reference-tictactoe

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Application base for HGOP 2016 Student project

Global installation requirements:

nodejs version 6.9.1 https://nodejs.org/en/

optional: yarn for package management (server only). https://yarnpkg.com/

Add ./node_modules/.bin to your path. This enables to you to run locally installed npm commands.

nodemon for watching server and restarting on modifications.

npm install -g nodemon

For developing React single-page-app (optional):

npm install -g create-react-app

Getting started:

Install and run postgres docker image for development.

docker run -p 5432:5432 --name pg2 -e POSTGRES_PASSWORD=mysecretpassword -d postgres

In project root directory:

yarn install (or npm install)

npm run migratedb

npm run start

To run server side tests in watch mode (in another terminal window):

npm run test

In another terminal window:

cd client
npm run start

At this point you should see the HGOP intro page open in your browser. If not, you should be able to point your browser to http://localhost:3000 and open it.

To run client tests in watch mode:

cd client
npm run test

To run API tests, simulating client calls to server socket-io api:

npm run apitest

To run API load tests, simulating client load on server socket-io api:

npm run loadtest

Notes

The main emphasis in this sample application is on object decomposition and testability, achieved with fine-grained objects wired together with aggressive use of dependency injection. The architecture style used is fully message based using Command Query Responsibility Segregation (CQRS) with event sourcing. This is an appropriate architecture for many classes of applications, such as where synchronizing views of multiple users is an important concern, and where achieving near-linear scaling of servers in clustered environments is a concern.

Note that transaction support, error handling and logging are incomplete, and many other details that would be required in production-ready clustered applications are not present. One such is persistent user sessions.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 94.2%
  • Shell 1.9%
  • CSS 1.8%
  • HTML 1.4%
  • CoffeeScript 0.7%