forked from solita/perfgraph
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.coffee
80 lines (65 loc) · 2.57 KB
/
server.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
express = require "express"
http = require "http"
path = require "path"
io = require "socket.io"
tulosteet = require "./server/tulosteet"
services = require "./server/services"
tietopalvelut = require "./server/tietopalvelut"
#memwatch = require "memwatch"
exec = require('child_process').exec
livereload = require('express-livereload')
app = express()
#memwatch.on('leak', (info) -> console.log info)
#memwatch.on('stats', (stats) -> console.log stats)
projects =
tulosteet: tulosteet
services: services
app.configure ->
app.set "port", process.env.PORT or 3000
app.set "host", process.env.IP or "0.0.0.0"
app.use express.favicon()
app.use express.logger("dev")
app.use express.compress()
app.use express.bodyParser() # Parse post-request body
app.use express.methodOverride() # http://stackoverflow.com/questions/8378338/what-does-connect-js-methodoverride-do
app.use app.router
app.use express.static(path.join(__dirname, "public"))
# Catch-all rule to handle reloads with client-side routing
app.use (req, res) -> res.sendfile path.join(__dirname, "public/index.html")
app.configure "development", ->
app.use express.errorHandler()
app.get "/response-time-trend/:project/:testCaseId/:limit", ({params: {project, testCaseId, limit}}, res) ->
p = projects[project]
p.responseTimeTrendInBuckets(testCaseId, parseInt limit )
.then((trend) -> res.send trend)
.done()
app.get "/error-trend/:project/:testCase", ({params: {project, testCaseId}}, res) ->
p = projects[project]
p.errorTrend(testCaseId)
.then((trend) -> res.send trend)
.done()
app.get "/throughput/:api/:limit", ({params: {api, limit}}, res) ->
tietopalvelut.throughput(api, parseInt limit)
.then((trend) -> res.send trend)
.done()
app.get "/reports/:project/:testCaseId/:build.json", ({params: {project, testCaseId, build}}, res) ->
p = projects[project]
p.report(testCaseId, build)
.then((report) -> res.send report)
.done()
processingBuilds = false
app.get "/process-builds", (req, res) ->
res.send 200
unless processingBuilds
processingBuilds = true
exec 'coffee ./server/pull.coffee', (err, stdout, stderr) ->
processingBuilds = false
console.log stdout, stderr
io.sockets.emit "change"
app.get "/force-reload", (req, res) ->
res.send 200; io.sockets.emit "reload"
server = http.createServer(app)
io = io.listen(server)
server.listen app.get("port"), app.get("host"), ->
console.log "Express server listening on port #{app.get("port")}"
livereload(app, config={})