Ivan - Add file upload and download test [skip ci]

This commit is contained in:
Ivan Diaz 2017-01-13 21:58:59 -03:00
parent 012103c2ad
commit dffe4a87a0
6 changed files with 89 additions and 31 deletions

View File

@ -42,7 +42,7 @@ class InitSettingsController extends Controller {
'title' => 'Support Center', 'title' => 'Support Center',
'url' => 'http://www.opensupports.com/support', 'url' => 'http://www.opensupports.com/support',
'registration' => true, 'registration' => true,
'last-stat-day' => '20170101' //TODO: get current date 'last-stat-day' => '20170101', //TODO: get current date
'ticket-gap' => Hashing::generateRandomPrime(100000, 999999), 'ticket-gap' => Hashing::generateRandomPrime(100000, 999999),
'file-gap' => Hashing::generateRandomPrime(100000, 999999), 'file-gap' => Hashing::generateRandomPrime(100000, 999999),
'file-first-number' => Hashing::generateRandomNumber(100000, 999999), 'file-first-number' => Hashing::generateRandomNumber(100000, 999999),

View File

@ -55,3 +55,4 @@ require './system/recover-mail-template.rb'
require './system/disable-registration.rb' require './system/disable-registration.rb'
require './system/enable-registration.rb' require './system/enable-registration.rb'
require './system/get-stats.rb' require './system/get-stats.rb'
require './system/file-upload-download.rb'

View File

@ -1,5 +1,12 @@
$agent = Mechanize.new $agent = Mechanize.new
def plainRequest(path, data = {})
uri = 'http://localhost:8080' + path
response = $agent.post(uri, data)
return response
end
def request(path, data = {}) def request(path, data = {})
uri = 'http://localhost:8080' + path uri = 'http://localhost:8080' + path
response = $agent.post(uri, data) response = $agent.post(uri, data)

View File

@ -1,24 +0,0 @@
describe 'File Upload and Download' do
request('/user/logout')
Scripts.login("creator@os4.com", "creator")
it 'should upload file when creating ticket' do
file = File.new('upload.txt', 'w')
file.puts('file content')
result = request('/ticket/create', {
'csrf_userid' => $csrf_userid,
'csrf_token' => $csrf_token,
'title' => 'Ticket with file',
'content' => 'this is a ticket that contains a file',
'language' => 'en',
'file' => file
})
(result['status']).should.equal('success');
ticket = $database.getLastRow('ticket');
(ticket['file'].include? 'upload.txt').should.equal(true)
(File.exist?('../server/files' + ticket['file'])).should.equal(true)
end
end

View File

@ -0,0 +1,74 @@
describe 'File Upload and Download' do
request('/user/logout')
Scripts.login('creator@os4.com', 'creator')
it 'should upload file when creating ticket' do
file = File.new('../server/files/upload.txt', 'w+')
file.puts('file content')
file.close
result = request('/ticket/create', {
'csrf_userid' => $csrf_userid,
'csrf_token' => $csrf_token,
'title' => 'Ticket with file',
'content' => 'this is a ticket that contains a file',
'language' => 'en',
'departmentId' => 1,
'file' => File.open( "../server/files/upload.txt")
})
(result['status']).should.equal('success')
ticket = $database.getLastRow('ticket')
(ticket['file'].include? 'upload.txt').should.equal(true)
(File.exist? ('../server/files/' + ticket['file'])).should.equal(true)
end
it 'should download file if author is logged' do
ticket = $database.getLastRow('ticket')
file = File.open("../server/files/" + ticket['file'])
result = plainRequest('/system/download', {
'csrf_userid' => $csrf_userid,
'csrf_token' => $csrf_token,
'file' => ticket['file']
})
(result.body).should.equal(file.read)
end
it 'should not download if author is not logged' do
request('/user/logout')
Scripts.login('staff@opensupports.com', 'staff', true)
ticket = $database.getLastRow('ticket')
result = plainRequest('/system/download', {
'csrf_userid' => $csrf_userid,
'csrf_token' => $csrf_token,
'file' => ticket['file']
})
(result.body).should.equal('')
end
it 'should download if owner is logged' do
ticket = $database.getLastRow('ticket')
file = File.open("../server/files/" + ticket['file'])
request('/staff/assign-ticket', {
'csrf_userid' => $csrf_userid,
'csrf_token' => $csrf_token,
'ticketNumber' => ticket['ticket_number']
})
result = plainRequest('/system/download', {
'csrf_userid' => $csrf_userid,
'csrf_token' => $csrf_token,
'file' => ticket['file']
})
(result.body).should.equal(file.read)
end
end

View File

@ -25,10 +25,10 @@ describe'/system/get-stats' do
$database.query("INSERT INTO log VALUES('', 'COMMENT', NULL, " + yesterday3 + ", NULL, NULL);") $database.query("INSERT INTO log VALUES('', 'COMMENT', NULL, " + yesterday3 + ", NULL, NULL);")
end end
for i in 0..8 for i in 0..8
$database.query("INSERT INTO ticketevent VALUES('', 'CLOSE', NULL, " + yesterday3 + ", NULL, NULL, 1);") $database.query("INSERT INTO ticketevent VALUES('', 'CLOSE', NULL, NULL, " + yesterday3 + ", NULL, NULL, 1);")
end end
for i in 0..4 for i in 0..4
$database.query("INSERT INTO ticketevent VALUES('', 'ASSIGN', NULL, " + yesterday3 + ", NULL, NULL, 1);") $database.query("INSERT INTO ticketevent VALUES('', 'ASSIGN', NULL, NULL, " + yesterday3 + ", NULL, NULL, 1);")
end end
#day 2 #day 2
@ -45,10 +45,10 @@ describe'/system/get-stats' do
$database.query("INSERT INTO log VALUES('', 'COMMENT', NULL, " + yesterday2 + ", NULL, NULL);") $database.query("INSERT INTO log VALUES('', 'COMMENT', NULL, " + yesterday2 + ", NULL, NULL);")
end end
for i in 0..10 for i in 0..10
$database.query("INSERT INTO ticketevent VALUES('', 'CLOSE', NULL, " + yesterday2 + ", NULL, NULL, 1);") $database.query("INSERT INTO ticketevent VALUES('', 'CLOSE', NULL, NULL, " + yesterday2 + ", NULL, NULL, 1);")
end end
for i in 0..2 for i in 0..2
$database.query("INSERT INTO ticketevent VALUES('', 'ASSIGN', NULL, " + yesterday2 + ", NULL, NULL, 1);") $database.query("INSERT INTO ticketevent VALUES('', 'ASSIGN', NULL, NULL, " + yesterday2 + ", NULL, NULL, 1);")
end end
#day 3 #day 3
@ -65,10 +65,10 @@ describe'/system/get-stats' do
$database.query("INSERT INTO log VALUES('', 'COMMENT', NULL, " + yesterday + ", NULL, NULL);") $database.query("INSERT INTO log VALUES('', 'COMMENT', NULL, " + yesterday + ", NULL, NULL);")
end end
for i in 0..3 for i in 0..3
$database.query("INSERT INTO ticketevent VALUES('', 'CLOSE', NULL, " + yesterday + ", NULL, NULL, 1);") $database.query("INSERT INTO ticketevent VALUES('', 'CLOSE', NULL, NULL, " + yesterday + ", NULL, NULL, 1);")
end end
for i in 0..7 for i in 0..7
$database.query("INSERT INTO ticketevent VALUES('', 'ASSIGN', NULL, " + yesterday + ", NULL, NULL, 1);") $database.query("INSERT INTO ticketevent VALUES('', 'ASSIGN', NULL, NULL, " + yesterday + ", NULL, NULL, 1);")
end end
@result = request('/system/get-stats', { @result = request('/system/get-stats', {