Compare commits

..

1 Commits

Author SHA1 Message Date
rnhmjoj
146a15b7d3 update doge script for matrix 2017-02-26 17:28:15 +01:00
29 changed files with 3336 additions and 3150 deletions

4
.gitignore vendored
View File

@ -1,5 +1,5 @@
node_modules node_modules
.hubot_history .hubot_history
.nyc_output
matrix-data matrix-data
report config/
coverage/

View File

@ -11,7 +11,7 @@ Asjon può:
- creare memes - creare memes
- fare calcoli e risolvere problemi con wolfram|alpha - fare calcoli e risolvere problemi con wolfram|alpha
- inviare immagini di [RMS](https://en.wikipedia.org/wiki/Richard_Stallman) - inviare immagini di [RMS](https://en.wikipedia.org/wiki/Richard_Stallman)
- invitare persone in una stanza - invitare persone in un gruppo di telegram
- dare informazioni sui propri contatti - dare informazioni sui propri contatti
- aprire [reverse shell](http://unix.stackexchange.com/q/46235) - aprire [reverse shell](http://unix.stackexchange.com/q/46235)
- aggiornarsi ed eseguire test autonomamente - aggiornarsi ed eseguire test autonomamente
@ -24,7 +24,7 @@ dell'IIS Galileo Galilei di Crema.
## Usare Asjon ## Usare Asjon
Asjon è sempre online su [matrix](https://matrix.org/) con l'username `@asjon:maxwell.ydns.eu` Asjon è sempre online su Telegram con l'username `Asjon ROBOT`
## Sviluppare Asjon ## Sviluppare Asjon
@ -36,9 +36,9 @@ correttamente (ad esempio i dati di accesso al registro elettronico per l'agenda
Asjon necessita di: Asjon necessita di:
- `node` e `yarn` - `node` e `npm`
- `redis` se si vuole salvare la sua memoria in maniera persistente - `redis` se si vuole salvare la sua memoria in maniera persistente
- `graphicsmagick` per la compressione delle immagini - `telegram-cli` con supporto python per l'adapter di telegram
### Installazione ### Installazione
@ -50,18 +50,18 @@ eseguendo
nella directory. Nella nuova shell installare asjon con nella directory. Nella nuova shell installare asjon con
$ yarn install $ npm install
### Utilizzo ### Utilizzo
Puoi avviare asjon tramite `nix-shell` con Puoi avviare asjon tramite `nix-shell` con
$ nix-shell --argstr mode run $ nix-shell --arg mode \"run\"
Altre `mode` possibili sono: Altre `mode` possibili sono:
* `run`: avvia asjon sull'adapter di maxwell (è necessario impostare user/pass con le rispettie variabili) * `runTg`: avvia asjon sull'adapter di telegram (è necessario fare il login al primo utilizzo)
* `test`: esegui i test d'integritĂ  * `test`: esegui i test d'integritĂ 
* `shell` (default): apre una nix-shell * `shell` (default): apre una nix-shell
@ -82,9 +82,9 @@ Asjon dispone di alcuni test d'integritĂ  nella cartella `test/`.
Per eseguirli, occorre: Per eseguirli, occorre:
1. installare [mocha](http://mochajs.org) tramite `yarn global add mocha` 1. installare [mocha](http://mochajs.org) tramite `npm install -g mocha` (potrebbe essere necessario sudo)
1. lanciare i test tramite `yarn test` dalla cartella della repo 1. lanciare i test tramite `npm test` dalla cartella della repo
1. opzionalmente è possibile generare i report di copertura dei test usando `yarn coverage`. 1. opzionalmente è possibile generare i report di copertura dei test usando `npm run coverage-html` o `npm run coverage-json` in base al formato desiderato.
__Nota Bene:__ è opportuno __eseguire sempre i test d'integrità prima di contribuire una modifica__. Ancora meglio sarebbe __Nota Bene:__ è opportuno __eseguire sempre i test d'integrità prima di contribuire una modifica__. Ancora meglio sarebbe
allegare dei test di integritĂ  insieme alle nuove funzioni aggiunte allegare dei test di integritĂ  insieme alle nuove funzioni aggiunte
@ -100,8 +100,8 @@ La [Scripting Guide](scripting-docs) di hubot è molto utile per imparare come f
Asjon può essere hostato come un qualsiasi Hubot. Asjon può essere hostato come un qualsiasi Hubot.
Il ramo `master` di Asjon è sempre hostato online ed è accessibile tramite matrix all'username Il ramo `master` di Asjon è sempre hostato online ed è accessibile tramite telegram all'username
`@asjon:maxwell.ydns.eu`. Asjon ROBOT.
## Licenza ## Licenza

View File

@ -3,4 +3,4 @@ set -e
export PATH="node_modules/.bin:node_modules/hubot/node_modules/.bin:$PATH" export PATH="node_modules/.bin:node_modules/hubot/node_modules/.bin:$PATH"
export DEBUG=nightmare export DEBUG=nightmare
node_modules/.bin/hubot --name asjon --alias assa "$@" node_modules/.bin/hubot --name "asjon" --alias "assa" "$@"

View File

@ -3,57 +3,41 @@
"version": "1.8.0", "version": "1.8.0",
"private": true, "private": true,
"author": "Enrico Fasoli <fazius2009@gmail.com>", "author": "Enrico Fasoli <fazius2009@gmail.com>",
"description": "our local chat bot", "description": "Il miglior amico della 5IA",
"dependencies": { "dependencies": {
"async": "^2.6.1", "async": "^1.4.2",
"chai": "^4.1.2", "chai": "^2.3.0",
"cheerio": "^1.0.0-rc.2", "cheerio": "^0.19.0",
"coffeescript": "^1.9.2", "coffee-coverage": "^0.4.6",
"fast-levenshtein": "^2.0.6", "coffee-script": "^1.9.2",
"mocha": "^5.2.0", "fast-levenshtein": "^1.0.6",
"mochawesome": "^3.0.1", "github": "^0.2.4",
"mock-fs": "^4.5.0", "hubot": "^2.12.0",
"nyc": "^13.0.0",
"moment": "^2.22.2",
"needle": "^2.2.1",
"nock": "^9.3.3",
"valid-url": "^1.0.9",
"hubot": "^2.19.0",
"hubot-bitcoin": "^1.0.3", "hubot-bitcoin": "^1.0.3",
"hubot-diagnostics": "0.0.2", "hubot-diagnostics": "0.0.1",
"hubot-google-images": "^0.2.7", "hubot-google-images": "^0.1.4",
"hubot-google-translate": "^0.2.1", "hubot-google-translate": "^0.1.0",
"hubot-help": "^0.2.2", "hubot-help": "^0.1.1",
"hubot-heroku-keepalive": "1.0.3", "hubot-heroku-keepalive": "0.0.4",
"hubot-maps": "0.0.3", "hubot-maps": "0.0.2",
"hubot-mock-adapter": "^1.0.0", "hubot-mock-adapter": "^1.0.0",
"hubot-pugme": "^0.1.1", "hubot-pugme": "^0.1.0",
"hubot-redis-brain": "0.0.4", "hubot-redis-brain": "0.0.2",
"hubot-rules": "^0.1.2", "hubot-rules": "^0.1.0",
"hubot-scripts": "^2.17.2", "hubot-scripts": "^2.5.16",
"hubot-shipit": "^0.2.1", "hubot-shipit": "^0.2.0",
"hubot-matrix": "git+https://maxwell.ydns.eu/git/rnhmjoj/hubot-matrix.git", "hubot-tg": "davidar/hubot-matrix",
"hubot-youtube": "^1.1.0" "hubot-youtube": "^0.1.2",
"mocha": "^3.2.0",
"moment": "^2.10.2",
"needle": "^0.10.0",
"nock": "^1.7.1",
"valid-url": "^1.0.9"
}, },
"scripts": { "scripts": {
"test": "nyc mocha; true" "coverage-html": "mkdir -p coverage && mocha test/ --require coffee-coverage/register --compilers coffee:coffee-script/register -R html-cov scripts/ > coverage/coverage.html",
}, "coverage-json": "mkdir -p coverage && mocha test/ --require coffee-coverage/register --compilers coffee:coffee-script/register -R json-cov scripts/ > coverage/coverage.json",
"nyc": { "test": "mocha test/ --compilers coffee:coffee-script/register"
"include": [
"scripts/*.coffee"
],
"extension": [ ".coffee" ],
"require": [
"coffeescript/register"
],
"reporter": [
"json-summary",
"html"
],
"report-dir": "report/coverage",
"sourceMap": true,
"instrument": true,
"cache": true
}, },
"engines": { "engines": {
"node": "0.10.x" "node": "0.10.x"

View File

@ -1,45 +0,0 @@
# Description:
# shows integrity tests coverage
#
# Dependencies:
# None
#
# Configuration:
# None
#
# Commands:
# hubot (mostrami la) copertura (dei test)
#
# Author:
# Enrico Fasoli (fazo96)
moment = require 'moment'
path = require 'path'
fs = require 'fs'
module.exports = (robot) ->
robot.respond /(?:mostrami la )?(?:copertura|coverage)(?: dei test)?/i, (res) ->
url = 'https://maxwell.ydns.eu/asjon/report/coverage'
file = 'report/coverage/coverage-summary.json'
try
report = JSON.parse (fs.readFileSync file, 'utf8')
catch err
if err.code is 'ENOENT'
return res.send 'report non disponibile. forse \
non è ancora stato generato?'
else
return res.send "errore nel leggere il report:\n#{err}"
files = []
for name, file of report
if name isnt "total"
files.push "- #{path.basename name} is covered at #{file.lines.pct}%"
res.send """
=== Coverage: #{report.total.lines.pct}%
#{files.join '\n'}
HTML report: #{url}
JSON report: #{url}/coverage-summary.json
"""

View File

@ -1,94 +0,0 @@
# Description:
# deep fry an image
#
# Commands:
# hubot deepfry/friggi[mi] <url>
#
# Dependencies:
# "async": "^1.4.2",
# "hubot-matrix": "rnhmjoj/hubot-matrix",
# "needle": "^0.10.0",
#
# Configuration:
# None
#
# Author:
# Michele Guerini Rocco (rnhmjoj)
ne = require 'needle'
async = require 'async'
gm = require 'gm'
url = require 'url'
module.exports = (robot) ->
# utilities
concat = (x) -> [].concat.apply([], x)
init = (x) -> (f) -> f(null, x)
times = (n, x) -> x for i in [1..n]
rand = (min, max) -> Math.random() * (max - min) + min
# effects
compress = (image, callback) ->
gm(image)
.noProfile()
.noise('uniform')
.quality(rand(30,80))
.noise('uniform')
.toBuffer callback
resize = (image, callback) ->
gm(image)
.scale('95%')
.scale('105%')
.toBuffer callback
colorize = (image, callback) ->
gm(image)
.modulate(rand(100,110), rand(100,150))
.toBuffer callback
deepFry = (res, image) ->
script = concat [
init(image),
resize,
colorize
times(50, compress),
]
async.waterfall script, (err, image) ->
if err?
robot.logger.warning "frying failed:\n#{err}"
return res.send 'scusa, si è rotta la friggitrice.'
# send image
robot.logger.info 'image fried successfully'
robot.adapter.sendImage
room: res.message.room
, image, 'fried.jpeg', ->
res.reply res.random [ 'meme fritto per te.', 'eccoti servito.']
robot.respond /(?:deepfry|friggi(?:mi)?) (questo|.+)/i, (res) ->
if not url.parse(res.match[1]).hostname
return res.send res.random [ 'non si usa così.', 'è un url questo?', 'cosa?' ]
imageURL = res.match[1]
# supported image mime types
accepted = ['image/jpeg', 'image/png', 'image/tiff']
# fetch headers
ne.head imageURL, follow_max: 5, (err, re) ->
if err?
robot.logger.warning "headers download failed:\n#{err}"
return res.send 'non riesco ad aprire il link.'
mimetype = re.headers['content-type'].split(';')[0]
if not (mimetype in accepted)
robot.logger.info 'url is not an image'
return res.send "non è un'immagine questo!"
# download and process
robot.logger.info 'downloading image...'
ne.get imageURL, follow_max: 5, (err, re, body) ->
robot.logger.info 'image downloaded'
deepFry res, body

37
scripts/drone.coffee Normal file
View File

@ -0,0 +1,37 @@
# Description:
# integrazione con drone.io e funzioni annesse
#
# Dependencies:
# None
#
# Configuration:
# None
#
# Commands:
# hubot (mostrami la) copertura (dei test)
#
# Author:
# Enrico Fasoli (fazo96)
moment = require 'moment'
module.exports = (robot) ->
robot.respond /(?:mostrami la )?(?:copertura|coverage)(?: dei test)?/i, (res) ->
url = 'https://drone.io/github.com/fazo96/asjon/files/coverage/coverage.'
robot.http(url+'json')
.get() (err, resp, body) ->
try
report = JSON.parse body
catch e
if /^404/g.test body
return res.send 'Coverage report non disponibile (404) forse \
non è ancora stato generato?'
return res.send 'Errore: '+e+'\n\nRisposta del server: '+body
unless report?.files?.push? and report?.coverage?.toFixed?
return res.send 'Errore: informazioni insufficienti'
t = '=== Coverage: ' + report.coverage.toFixed(0) + '%'
t += report.files.map (f) ->
'\n - ' + f.filename + ' is covered at ' + f.coverage.toFixed(0) + '%'
t += '\nHTML report: '+url+'html'
t += '\nJSON report: '+url+'json'
res.send t

View File

@ -1,69 +0,0 @@
# Description:
# interazioni tra asjon e git
#
# Dependencies:
# None
#
# Configuration:
# HUBOT_GIT_URL - git server url
# HUBOT_GIT_API - git server API url
# HUBOT_GIT_TOKEN - Gogs v1 or GitHub v3 API token
# HUBOT_GIT_REPO - repository name (owner/repo)
#
# Commands:
# asjon mostra le issue - mostra le issue aperte su rnhmjoj/asjon
#
# Author:
# Enrico Fasoli (fazo96)
# Michele Guerini Rocco (rnhmjoj)
module.exports = (robot) ->
githook = (req, res) ->
res.send 200
dest = name: req.params.name, room: id: req.params.room
robot.emit 'githook', req.body, req.params
s = "branch #{req.body.ref} aggiornato!\n"
cm = req.body.commits.map (c) ->
[c.committer.username, c.message].join ' -> '
robot.send dest, s + cm.join '\n'
unless process.env.TESTING_ASJON
# Disabilito http route durante i test
robot.router.post '/hubot/githook/:room/:name?', githook
robot.respond /(?:(?:mostra(?:mi)?|fammi vedere) )?(?:le )?issue(?:s)?/i, (res) ->
msg = state: 'open', user: 'rnhmjoj', repo: 'asjon', sort: 'updated'
res.send 'controllo issues...'
url = process.env.HUBOT_GIT_API
repo = process.env.HUBOT_GIT_REPO
token = process.env.HUBOT_GIT_TOKEN
if not token
return res.send 'non ho il token per la repo'
robot.http("#{url}/repos/#{repo}/issues?state=open&sort=updated")
.header('Authorization', 'token '+token)
.get() (err, r, body) ->
if err then return res.send err
data = JSON.parse body
if data.length is 0 then return res.send '0 issues'
r = data.map (i) ->
labels = i.labels.map((x) -> x.name).join ', '
if labels is '' then labels = 'nessuno'
["#"+i.number,i.title,"By: "+i.user.login,'Tags: '+labels].join(' | ')
res.send r.join '\n'
robot.respond /linkami (?:la )?issue (?:(?:n(?:°)?(?: )?)|numero )?(\d+)/i, (res) ->
url = process.env.HUBOT_GIT_URL
repo = process.env.HUBOT_GIT_REPO
base = "#{url}/#{repo}/issues/"
res.send base+res.match[1]
robot.respond /linkami (?:la )?repo (\w+\/\w+)/i, (res) ->
url = process.env.HUBOT_GIT_URL
res.send "#{url}/#{res.match[1]}/"
# rendo l'handler dell'hook di git accessibile
# in caso serve (nei test)
return githook

52
scripts/github.coffee Normal file
View File

@ -0,0 +1,52 @@
# Description:
# interazioni tra asjon e github
#
# Requires:
# "github": "0.2.4"
#
# Commands:
# asjon mostra le issue - mostra le issue aperte su fazo96/asjon
#
# Author:
# Enrico Fasoli (fazo96)
GitHubAPI = require 'github'
github = new GitHubAPI version: '3.0.0'
module.exports = (robot) ->
githubhook = (req, res) ->
res.send 200
dest = name: req.params.name, room: req.params.room.replace(':','#')
robot.emit 'githubhook', req.body, req.params
s = 'Branch '+req.body.ref+' aggiornato!\n'
cm = req.body.commits.map (c) ->
[c.committer.username,c.message].join ' -> '
robot.send dest, s+cm.join('\n')
unless process.env.TESTING_ASJON
# Disabilito http route durante i test
robot.router.post '/hubot/githubhook/:room/:name?', githubhook
robot.respond /(?:(?:mostra(?:mi)?|fammi vedere) )?(?:le )?issue(?:s)?/i, (res) ->
msg = state: 'open', user: 'fazo96', repo: 'asjon', sort: 'updated'
res.send 'controllo issues...'
github.issues.repoIssues msg, (err,data) ->
if err then return res.send err
if data.length is 0 then return res.send '0 issues'
r = data.map (i) ->
labels = i.labels.map((x) -> x.name).join ', '
if labels is '' then labels = 'nessuno'
["#"+i.number,i.title,"By: "+i.user.login,'Tags: '+labels].join(' | ')
res.send r.join '\n'
robot.respond /linkami (?:la )?issue (?:(?:n(?:°)?(?: )?)|numero )?(\d+)/i, (res) ->
base = 'http://github.com/fazo96/asjon/issues/'
res.send base+res.match[1]
robot.respond /linkami (?:la )?repo (\w+\/\w+)/i, (res) ->
res.send 'https://github.com/'+res.match[1]
# rendo l'handler dell'hook di github accessibile
# in caso serve (nei test)
return githubhook

View File

@ -0,0 +1,68 @@
# Description:
# What you are referring to is actually GNU + Linux....
#
# Configuration:
# None
#
# Author:
# Enrico Fasoli (fazo96)
image1 = 'https://lut.im/trSfl2cdfX/TDIkX3SjLhKJ2qm5.jpg'
image2 = 'https://lut.im/PLRw8AxYlI/UYH3pv7MWkROQ2BW.jpg'
song = 'https://www.youtube.com/watch?v=9sJUDx7iEJw'
interjection = "
I’d just like to interject for a moment. What you’re referring to as Linux, is
in fact, GNU/Linux, or as I’ve recently taken to calling it, GNU plus Linux.
Linux is not an operating system unto itself, but rather another free component
of a fully functioning GNU system made useful by the GNU corelibs, shell
utilities and vital system components comprising a full OS as defined by POSIX.
Many computer users run a modified version of the GNU system every day, without
realizing it. Through a peculiar turn of events, the version of GNU which is
widely used today is often called “Linux”, and many of its users are not aware
that it is basically the GNU system, developed by the GNU Project.
There really is a Linux, and these people are using it, but it is just a part of
the system they use. Linux is the kernel: the program in the system that
allocates the machine’s resources to the other programs that you run. The kernel
is an essential part of an operating system, but useless by itself; it can only
function in the context of a complete operating system. Linux is normally used
in combination with the GNU operating system: the whole system is basically GNU
with Linux added, or GNU/Linux. All the so-called “Linux” distributions are
really distributions of GNU/Linux.
"
interjection_es = "
Me gustarĂ­a interponer por un sĂłlo momento. Lo que usted se refiere como Linux,
es, de hecho, GNU/Linux, o como recientemente yo he empezado a llamar, GNU plus
Linux. Linux no es un sistema operativo en sí mismo, sino más bien otro
componente libre de un sistema GNU enteramente functional, hacho Ăştil por los
GNU corelibs, utilidades de shell y los componentes vitales del sistema que
comprende un sistema operativo completo segĂşn lo definido por POSIX.
Muchos usuarios de computadoras ejecutan una versiĂłn modificada del sistema GNU
todos los días, sin darse cuenta. A través de un giro peculiar de eventos, la
versiĂłn de GNU, que es ampliamente utilizado hoy en dĂ­a es a menudo llamado
“Linux”, y muchos de sus usuarios no son conscientes de que es básicamente el
sistema GNU, desarrollado por el proyecto GNU.
Realmente hay un Linux, y estas personas lo están utilizando, pero es sólo una
parte del sistema que utilizan. Linux es el nĂşcleo: el programa en el sistema
que asigna los recursos de la máquina a los otros programas que se ejecutan.
El nĂşcleo es una parte esencial de un sistema operativo, pero inĂştil por sĂ­
mismo; sĂłlo puede funcionar en el contexto de un sistema operativo completo.
Linux se utiliza normalmente en combinaciĂłn con el sistema operativo GNU:
todo el sistema es básicamente GNU con Linux agregado, o GNU/Linux. Todas las
llamadas distribuciones de “Linux” son realmente distribuciones de GNU/Linux.
"
module.exports = (robot) ->
robot.hear /linux/i, (res) ->
s = res.message.text
if not s.match /(GNU ?[+\/])|(kernel )Linux/i
if Math.random() < 0.1
res.send image2, interjection_es, song
else
res.send image1, interjection

View File

@ -16,7 +16,7 @@
moment = require 'moment' moment = require 'moment'
regex = /(?:(?:(?:(?:mi (?:dici|dai)|dammi) (?:il (?:tempo|meteo)|(?:le previsioni)))(?: ?(?:(?:per ?(?:(?:l')|il |lo |la |i |gli |le )?)|di |a ))?|(?:che tempo (?:fa|(?:c'?(?:è|e|e')))(?: ?(?:in|a) )?))|meteo)([^?!]+)?.*$/i regex = /(?:(?:d(?:a|i)mmi il )?meteo(?: per (.+))?|che tempo (?:fa|c'è)(?: (?:a|in) (.+))?)\??$/i
url1 = 'http://ip-api.com/json/' url1 = 'http://ip-api.com/json/'
url2 = 'http://api.openweathermap.org/data/2.5/weather?lang=it&units=metric' url2 = 'http://api.openweathermap.org/data/2.5/weather?lang=it&units=metric'
@ -64,7 +64,7 @@ module.exports = (robot) ->
tramonto alle #{dusk}" tramonto alle #{dusk}"
robot.respond regex, (res) -> robot.respond regex, (res) ->
city = res.match[1] city = res.match[1] || res.match[2]
if city? if city?
get_weather city, send_weather res get_weather city, send_weather res
else else

View File

@ -124,5 +124,5 @@ module.exports = (robot) ->
robot.respond /ci sei\?/i, (res) -> robot.respond /ci sei\?/i, (res) ->
res.send res.random confirm res.send res.random confirm
robot.hear /\bassa\?/, (res) -> robot.hear /assa\?/, (res) ->
res.send res.random confirm res.send res.random confirm

View File

@ -5,7 +5,7 @@
# None # None
# #
# Commands: # Commands:
# asjon run/esegui/shell git/yarn args... # asjon run/esegui/shell git/npm args...
# #
# Author: # Author:
# Enrico Fasoli (fazo96) # Enrico Fasoli (fazo96)
@ -41,7 +41,7 @@ module.exports = (robot) ->
if process.env.AUTO_RUN_TESTS and process.env.ADMIN_ROOM if process.env.AUTO_RUN_TESTS and process.env.ADMIN_ROOM
dest = room: process.env.ADMIN_ROOM dest = room: process.env.ADMIN_ROOM
dest.send = (x) -> robot.send dest, x dest.send = (x) -> robot.send dest, x
runCmd 'yarn test', dest runCmd 'npm test', dest
if process.env.AUTO_INFORM_ON_START if process.env.AUTO_INFORM_ON_START
room = id: process.env.AUTO_INFORM_ON_START room = id: process.env.AUTO_INFORM_ON_START
@ -49,7 +49,7 @@ module.exports = (robot) ->
robot.respond /aggiornati|scarica (?:gli )?aggiornamenti/i, (res) -> robot.respond /aggiornati|scarica (?:gli )?aggiornamenti/i, (res) ->
return res.send res.random nope unless isFromAdmin res return res.send res.random nope unless isFromAdmin res
runCmd 'git pull && yarn install', res runCmd 'git pull && npm install', res
robot.respond /(?:controlla gli )?aggiornamenti/i, (res) -> robot.respond /(?:controlla gli )?aggiornamenti/i, (res) ->
return res.send res.random nope unless isFromAdmin res return res.send res.random nope unless isFromAdmin res
@ -57,11 +57,11 @@ module.exports = (robot) ->
robot.respond /(?:installa (?:le )?)?dipendenze/i, (res) -> robot.respond /(?:installa (?:le )?)?dipendenze/i, (res) ->
return res.send res.random nope unless isFromAdmin res return res.send res.random nope unless isFromAdmin res
runCmd 'yarn install', res runCmd 'npm install', res
robot.respond /(?:esegui (?:i )?)?test/i, (res) -> robot.respond /(?:esegui (?:i )?)?test/i, (res) ->
return res.send res.random nope unless isFromAdmin res return res.send res.random nope unless isFromAdmin res
runCmd 'yarn test', res runCmd 'npm test', res
robot.respond /secret-kill-code/i, (res) -> robot.respond /secret-kill-code/i, (res) ->
return res.send res.random nope unless isFromAdmin res return res.send res.random nope unless isFromAdmin res
@ -85,11 +85,11 @@ module.exports = (robot) ->
runCmd ssh, res, -> runCmd ssh, res, ->
res.send "connessione chiusa. reverse shell terminata" res.send "connessione chiusa. reverse shell terminata"
robot.on 'githook', (data,params) -> robot.on 'githubhook', (data,params) ->
if data.ref is 'refs/heads/master' and process.env.AUTO_KILL_ON_UPDATE if data.ref is 'refs/heads/master' and process.env.AUTO_KILL_ON_UPDATE
dest = name: params.name, room: params.room dest = name: params.name, room: params.room
res = send: (x) -> robot.send dest, x res = send: (x) -> robot.send dest, x
runCmd 'git pull && yarn install', res, -> runCmd 'git pull && npm install', res, ->
robot.send dest, 'riavvio in 5 SECONDI' robot.send dest, 'riavvio in 5 SECONDI'
reboot = -> process.exit 0 reboot = -> process.exit 0
unless process.env.TESTING_ASJON unless process.env.TESTING_ASJON

View File

@ -1,28 +0,0 @@
{ pkgs ? import <nixpkgs> {}, mode ? "shell" }:
with pkgs.lib;
let
modes = {
shell = "exec fish";
test = "exec yarn test";
run = "exec bin/hubot -a matrix";
};
in pkgs.stdenv.mkDerivation rec {
name = "asjon-dev";
source = ".";
buildInputs = with pkgs; [
nodejs nodePackages.coffee-script
yarn openssh graphicsmagick
];
shellHook = environment + getAttr mode modes;
environment = ''
#set env variables here
export PATH="node_modules/.bin:$PATH"
export AUTO_KILL_ON_UPDATE=1
'';
}

View File

@ -1,7 +1,7 @@
nock = require 'nock' nock = require 'nock'
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
describe 'hubot mock', -> describe 'hubot mock', ->

View File

@ -1,7 +1,7 @@
nock = require 'nock' nock = require 'nock'
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
describe 'shell autostart', -> describe 'shell autostart', ->
@ -26,9 +26,9 @@ describe 'shell autostart', ->
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
if acc is 0 if acc is 0
l.join().should.equal 'operazione in corso: yarn test' l.join().should.equal 'operazione in corso: npm test'
if acc is 1 if acc is 1
l.join().should.equal 'operazione "completata": yarn test' l.join().should.equal 'operazione "completata": npm test'
acc++ acc++
if acc is 2 then done() if acc is 2 then done()
process.env.AUTO_RUN_TESTS = 'true' process.env.AUTO_RUN_TESTS = 'true'

View File

@ -1,62 +0,0 @@
expect = require("chai").should()
mock = require 'mock-fs'
Asjon = require './asjon-testing.coffee'
asjon = undefined
describe 'modulo coverage', ->
before (done) ->
# Inizializzo robot
Asjon (assa) ->
asjon = assa
after asjon.after
afterEach () ->
asjon.clear()
mock.restore()
require('../scripts/coverage.coffee')(asjon.robot)
done()
it 'dovrebbe rispondere quando interrogato', (done) ->
questions = [
"asjon mostrami la copertura dei test"
"asjon copertura dei test"
"asjon copertura"
"asjon coverage"
]
acc = 0
asjon.receive (e,l) ->
acc++
if acc is questions.length
done()
questions.map (q) -> asjon.send q
it 'dovrebbe reagire correttamente ad un errore di parsing', (done) ->
# broken report
mock
'report/coverage/coverage-summary.json': '{'
asjon.receive (e,l) ->
l.join().should.match /^errore nel leggere il report:\nSyntaxError/g
done()
asjon.send 'asjon coverage'
it 'dovrebbe reagire correttamente quando il report non è disponibile', (done) ->
# missing report
mock
'report/coverage/coverage-summary.json':
mock.symlink path: '/no-such-file'
asjon.receive (e,l) ->
l.join().should.match /^report non disponibile/g
done()
asjon.send 'asjon coverage'
it 'dovrebbe parsare correttamente il report json', (done) ->
# fake report
mock
'report/coverage/coverage-summary.json': JSON.stringify
total: lines: pct: 73.11
'a/b.coffee': lines: pct: 92.12
'a/c.coffee': lines: pct: 81.67
asjon.receive (e,l) ->
l.join().should.match /^=== Coverage: /g
done()
asjon.send 'asjon coverage'

3031
test/coverage.json Normal file

File diff suppressed because it is too large Load Diff

58
test/drone-test.coffee Normal file
View File

@ -0,0 +1,58 @@
nock = require 'nock'
expect = require("chai").should()
Asjon = require '../asjon-testing.coffee'
asjon = undefined
describe 'modulo drone', ->
before (done) ->
# Inizializzo robot
Asjon (assa) ->
asjon = assa
after asjon.after
afterEach asjon.clear
require('../scripts/drone.coffee')(asjon.robot)
done()
it 'dovrebbe rispondere quando interrogato', (done) ->
nock('https://drone.io')
.get('/github.com/fazo96/asjon/files/coverage/coverage.json')
.reply 200, { coverage: 0, files: [] }
questions = [
"asjon mostrami la copertura dei test"
"asjon copertura dei test"
"asjon copertura"
"asjon coverage"
]
acc = 0
asjon.receive (e,l) ->
acc++
if acc is questions.length then done()
questions.map (q) -> asjon.send q
it 'dovrebbe reagire correttamente a un errore', (done) ->
nock('https://drone.io')
.get('/github.com/fazo96/asjon/files/coverage/coverage.json')
.reply 200, 'invalid answer'
asjon.receive (e,l) ->
l.join().should.match /^Errore: SyntaxError: Unexpected token/g
done()
asjon.send 'asjon coverage'
it 'dovrebbe reagire correttamente quando il report non è disponibile (404)', (done) ->
nock('https://drone.io')
.get('/github.com/fazo96/asjon/files/coverage/coverage.json')
.reply 404, '404 page not found'
asjon.receive (e,l) ->
l.join().should.match /^Coverage report non disponibile/g
done()
asjon.send 'asjon coverage'
it 'dovrebbe parsare correttamente il report json', (done) ->
nock('https://drone.io')
.get('/github.com/fazo96/asjon/files/coverage/coverage.json')
.replyWithFile 200, __dirname+'/coverage.json'
asjon.receive (e,l) ->
l.join().should.match /^=== Coverage: /g
done()
asjon.send 'asjon coverage'

View File

@ -1,23 +1,19 @@
nock = require 'nock' nock = require 'nock'
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
githook = undefined githubhook = undefined
describe 'modulo git', -> describe 'modulo github', ->
before (done) -> before (done) ->
# Inizializzo robot # Inizializzo robot
Asjon (assa) -> Asjon (assa) ->
asjon = assa asjon = assa
after asjon.after after asjon.after
afterEach asjon.clear afterEach asjon.clear
githook = require('../scripts/git.coffee')(asjon.robot) githubhook = require('../scripts/github.coffee')(asjon.robot)
done() done()
process.env.HUBOT_GIT_URL = 'https://git.example.com'
process.env.HUBOT_GIT_API = 'https://api.example.com'
process.env.HUBOT_GIT_REPO = 'owner/asjon'
process.env.HUBOT_GIT_TOKEN = 'secret'
it 'dovrebbe rispondere a "mostra le issues"', (done) -> it 'dovrebbe rispondere a "mostra le issues"', (done) ->
questions = [ questions = [
@ -27,8 +23,8 @@ describe 'modulo git', ->
"asjon le issue" "asjon le issue"
"asjon issue" "asjon issue"
] ]
nock('https://api.example.com') nock('https://api.github.com')
.get('/repos/owner/asjon/issues?state=open&sort=updated') .get('/repos/fazo96/asjon/issues?state=open&sort=updated')
.times(questions.length) .times(questions.length)
.reply 200, [] .reply 200, []
acc = 0 acc = 0
@ -38,8 +34,8 @@ describe 'modulo git', ->
questions.map (q) -> asjon.send q questions.map (q) -> asjon.send q
it 'dovrebbe rispondere correttamente in caso di 0 issues', (done) -> it 'dovrebbe rispondere correttamente in caso di 0 issues', (done) ->
nock('https://api.example.com') nock('https://api.github.com')
.get('/repos/owner/asjon/issues?state=open&sort=updated') .get('/repos/fazo96/asjon/issues?state=open&sort=updated')
.reply 200, [] .reply 200, []
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
@ -66,8 +62,8 @@ describe 'modulo git', ->
login: 'user' login: 'user'
it 'dovrebbe rispondere correttamente in caso di 1 o piĂą issues', (done) -> it 'dovrebbe rispondere correttamente in caso di 1 o piĂą issues', (done) ->
nock('https://api.example.com') nock('https://api.github.com')
.get('/repos/owner/asjon/issues?state=open&sort=updated') .get('/repos/fazo96/asjon/issues?state=open&sort=updated')
.reply 200, [issue1, issue2] .reply 200, [issue1, issue2]
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
@ -85,16 +81,16 @@ describe 'modulo git', ->
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
if acc is 0 if acc is 0
l.join().should.equal 'https://git.example.com/owner/asjon/issues/5' l.join().should.equal 'http://github.com/fazo96/asjon/issues/5'
else else
l.join().should.equal 'https://git.example.com/owner/asjon/issues/456' l.join().should.equal 'http://github.com/fazo96/asjon/issues/456'
acc++ acc++
if acc is 2 then done() if acc is 2 then done()
asjon.send 'asjon linkami la issue numero 5' asjon.send 'asjon linkami la issue numero 5'
asjon.send 'asjon linkami issue 456' asjon.send 'asjon linkami issue 456'
it 'dovrebbe rendere disponibile l\'handler del webhook', -> it 'dovrebbe rendere disponibile l\'handler del webhook', ->
githook.should.not.be.undefined githubhook.should.not.be.undefined
it 'dovrebbe informare correttamente riguardo gli aggiornamenti', (done) -> it 'dovrebbe informare correttamente riguardo gli aggiornamenti', (done) ->
acc = 0 acc = 0
@ -109,15 +105,15 @@ describe 'modulo git', ->
send: (code) -> code.should.equal 200 send: (code) -> code.should.equal 200
asjon.receive (e,l) -> asjon.receive (e,l) ->
if acc is 0 if acc is 0
l.join().should.equal 'branch '+req.body.ref+' aggiornato!\n' l.join().should.equal 'Branch '+req.body.ref+' aggiornato!\n'
if acc is 1 if acc is 1
l.join().should.equal 'branch '+req.body.ref+' aggiornato!\ntest -> commit' l.join().should.equal 'Branch '+req.body.ref+' aggiornato!\ntest -> commit'
acc++ acc++
if acc is 2 then done() if acc is 2 then done()
githook req, res githubhook req, res
req.body.ref = 'refs/heads/master' req.body.ref = 'refs/heads/master'
req.body.commits.push req.body.commits.push
committer: committer:
username: 'test' username: 'test'
message: 'commit' message: 'commit'
githook req, res githubhook req, res

View File

@ -1,7 +1,7 @@
nock = require 'nock' nock = require 'nock'
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
describe 'modulo memes', -> describe 'modulo memes', ->

View File

@ -1,6 +1,6 @@
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
describe 'modulo memoria', -> describe 'modulo memoria', ->

View File

@ -1,7 +1,7 @@
nock = require 'nock' nock = require 'nock'
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
loc_payload = loc_payload =
@ -40,11 +40,7 @@ describe 'modulo meteo', ->
it 'dovrebbe rispondere quando interrogato', (done) -> it 'dovrebbe rispondere quando interrogato', (done) ->
process.env.WEATHER_API_KEY = key process.env.WEATHER_API_KEY = key
questions = [ questions = [
"asjon mi dici il tempo per roma?" "asjon che tempo c'è a crema"
"asjon dammi le previsioni!"
"asjon dammi le previsioni per milano"
"asjon mi dai il meteo per l'aquila?"
"asjon che tempo c'è in grecia?"
"asjon che tempo fa a crema?" "asjon che tempo fa a crema?"
"asjon che tempo c'è?" "asjon che tempo c'è?"
"asjon che tempo fa?" "asjon che tempo fa?"

View File

@ -1,3 +0,0 @@
test/*.coffee
--reporter mochawesome
--reporter-options reportDir=report,reportFilename=index,json=false,quiet=true

View File

@ -1,7 +1,7 @@
nock = require 'nock' nock = require 'nock'
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
describe 'modulo shell', -> describe 'modulo shell', ->
@ -34,7 +34,7 @@ describe 'modulo shell', ->
asjon.send 'asjon controlla gli aggiornamenti' asjon.send 'asjon controlla gli aggiornamenti'
it 'dovrebbe eseguire i comandi corretti per installare gli aggiornamenti', (done) -> it 'dovrebbe eseguire i comandi corretti per installare gli aggiornamenti', (done) ->
cmd = 'git pull && yarn install' cmd = 'git pull && npm install'
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
l.join().should.equal ss[acc]+cmd l.join().should.equal ss[acc]+cmd
@ -54,7 +54,7 @@ describe 'modulo shell', ->
asjon.send 'asjon controlla gli aggiornamenti' asjon.send 'asjon controlla gli aggiornamenti'
it 'dovrebbe eseguire i comandi corretti per installare le dipendenze', (done) -> it 'dovrebbe eseguire i comandi corretti per installare le dipendenze', (done) ->
cmd = 'yarn install' cmd = 'npm install'
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
l.join().should.equal ss[acc]+cmd l.join().should.equal ss[acc]+cmd
@ -64,7 +64,7 @@ describe 'modulo shell', ->
asjon.send 'asjon installa le dipendenze' asjon.send 'asjon installa le dipendenze'
it 'dovrebbe eseguire i comandi corretti per eseguire i test', (done) -> it 'dovrebbe eseguire i comandi corretti per eseguire i test', (done) ->
cmd = 'yarn test' cmd = 'npm test'
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
l.join().should.equal ss[acc]+cmd l.join().should.equal ss[acc]+cmd
@ -79,13 +79,13 @@ describe 'modulo shell', ->
acc = 0 acc = 0
asjon.receive (e,l) -> asjon.receive (e,l) ->
if acc is 0 if acc is 0
l.join().should.equal 'operazione in corso: git pull && yarn install' l.join().should.equal 'operazione in corso: git pull && npm install'
if acc is 1 if acc is 1
l.join().should.equal 'operazione "completata": git pull && yarn install' l.join().should.equal 'operazione "completata": git pull && npm install'
if acc is 2 if acc is 2
l.join().should.equal 'riavvio in 5 SECONDI' l.join().should.equal 'riavvio in 5 SECONDI'
acc++ acc++
if acc is 3 if acc is 3
done() done()
process.env.AUTO_KILL_ON_UPDATE = 'true' process.env.AUTO_KILL_ON_UPDATE = 'true'
asjon.robot.emit 'githook', data, params asjon.robot.emit 'githubhook', data, params

View File

@ -1,7 +1,7 @@
nock = require 'nock' nock = require 'nock'
expect = require("chai").should() expect = require("chai").should()
Asjon = require './asjon-testing.coffee' Asjon = require '../asjon-testing.coffee'
asjon = undefined asjon = undefined
describe 'modulo wolfram', -> describe 'modulo wolfram', ->

2735
yarn.lock

File diff suppressed because it is too large Load Diff