migliorata qualità codice, aumento copertura test

This commit is contained in:
Enrico Fasoli 2015-04-29 17:34:38 +02:00
parent 1ac7124a01
commit e0783e3a24
3 changed files with 52 additions and 12 deletions

View File

@ -18,20 +18,27 @@ isFromAdmin = (res) ->
res.message.user.room is process.env.ADMIN_ROOM?.replace(':','#') or res.robot.adapterName is 'shell'
runCmd = (cmd,res,cb) ->
if res? then res.send 'Operazione in corso: '+cmd
if res?.send? then res.send 'Operazione in corso: '+cmd
if process.env.TESTING_ASJON
# Fingi di eseguire l'operazione
if res? then res.send 'Operazione "completata": '+cmd
if cb? then cb null,'',''
if res?.send? then res.send 'Operazione "completata": '+cmd
if cb?.call? then cb null,'',''
else cp.exec cmd, (err,stdout,stderr) ->
if res?
if res?.send?
if err
res.send 'Operazione fallita:\n'+stdout+stderr
else
res.send 'Operazione completata:\n'+stdout
if cb? then cb err,stdout,stderr
if cb?.call? then cb err,stdout,stderr
module.exports = (robot) ->
# Lancia i test all'avvio
if process.env.AUTO_RUN_TESTS and process.env.ADMIN_ROOM
dest = room: process.env.ADMIN_ROOM.replace(':','#')
dest.send = (x) -> robot.send dest, x
runCmd 'npm test', dest
if process.env.AUTO_INFORM_ON_START
r = room: process.env.AUTO_INFORM_ON_START.replace(':','#')
robot.send r, 'asjon avviato e operativo!'
@ -52,12 +59,6 @@ module.exports = (robot) ->
if !isFromAdmin(res) then return res.send res.random nope
runCmd 'npm test', res
# Run tests on boot and report to ADMIN
if process.env.AUTO_RUN_TESTS and process.env.ADMIN_ROOM
dest = room: process.env.ADMIN_ROOM.replace(':','#')
dest.send = (x) -> robot.send dest, x
runCmd 'npm test', dest
robot.on 'githubhook', (data,params) ->
if data.ref is 'refs/heads/master' and process.env.AUTO_KILL_ON_UPDATE
dest = name: params.name, room: params.room.replace(':','#')

View File

@ -0,0 +1,34 @@
nock = require 'nock'
expect = require("chai").should()
Asjon = require '../asjon-testing.coffee'
asjon = undefined
describe 'shell autostart', ->
before (done) ->
# Inizializzo robot
Asjon (assa) ->
asjon = assa
after asjon.after
afterEach asjon.clear
done()
it 'dovrebbe informare dell\'avvio se richiesto', (done) ->
asjon.receive (e,l) ->
l.join().should.equal 'asjon avviato e operativo!'
done()
process.env.AUTO_INFORM_ON_START = ':mocha'
require('../scripts/shell.coffee')(asjon.robot)
it 'dovrebbe eseguire i test all\'avvio se richiesto', (done) ->
acc = 0
asjon.receive (e,l) ->
if acc is 0
l.join().should.equal 'Operazione in corso: npm test'
if acc is 1
l.join().should.equal 'Operazione "completata": npm test'
acc++
if acc is 2 then done()
process.env.AUTO_RUN_TESTS = 'true'
process.env.ADMIN_ROOM = ':mocha'
require('../scripts/shell.coffee')(asjon.robot)

View File

@ -18,18 +18,19 @@ describe 'modulo shell', ->
asjon.receive (e,l) ->
l.join().should.match /BZBZ (.+)/i
done()
process.env.ADMIN_ROOM = ':not-mocha'
asjon.send 'asjon controlla gli aggiornamenti'
ss = ['Operazione in corso: ', 'Operazione "completata": ']
regexes = [/Operazione in corso: (.+)/i, /Operazione "completata": (.+)/i]
it 'dovrebbe riconoscere la stanza autorizzata', (done) ->
process.env.ADMIN_ROOM = ':mocha'
acc = 0
asjon.receive (e,l) ->
l.join().should.match regexes[acc]
acc++
if acc is 2 then done()
process.env.ADMIN_ROOM = ':mocha'
asjon.send 'asjon controlla gli aggiornamenti'
it 'dovrebbe eseguire i comandi corretti per installare gli aggiornamenti', (done) ->
@ -39,6 +40,7 @@ describe 'modulo shell', ->
l.join().should.equal ss[acc]+cmd
acc++
if acc is 2 then done()
process.env.ADMIN_ROOM = ':mocha'
asjon.send 'asjon aggiornati'
it 'dovrebbe eseguire i comandi corretti per controllare gli aggiornamenti', (done) ->
@ -48,6 +50,7 @@ describe 'modulo shell', ->
l.join().should.equal ss[acc]+cmd
acc++
if acc is 2 then done()
process.env.ADMIN_ROOM = ':mocha'
asjon.send 'asjon controlla gli aggiornamenti'
it 'dovrebbe eseguire i comandi corretti per installare le dipendenze', (done) ->
@ -57,6 +60,7 @@ describe 'modulo shell', ->
l.join().should.equal ss[acc]+cmd
acc++
if acc is 2 then done()
process.env.ADMIN_ROOM = ':mocha'
asjon.send 'asjon installa le dipendenze'
it 'dovrebbe eseguire i comandi corretti per eseguire i test', (done) ->
@ -66,6 +70,7 @@ describe 'modulo shell', ->
l.join().should.equal ss[acc]+cmd
acc++
if acc is 2 then done()
process.env.ADMIN_ROOM = ':mocha'
asjon.send 'asjon esegui i test'
it 'dovrebbe autoriavviarsi in caso di update se richiesto', (done) ->