Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add integration tests #157

Open
wants to merge 8 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 17 additions & 2 deletions addon/components/file-field.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import Ember from 'ember';

export default Ember.Component.extend(Ember.Evented, {
const { Component, Evented } = Ember;

export default Component.extend(Evented, {
tagName: 'input',
type: 'file',
attributeBindings: [
Expand All @@ -14,7 +16,20 @@ export default Ember.Component.extend(Ember.Evented, {
'multiple'
],
multiple: false,
change (event) {

didInsertElement (...args) {
this._super(...args);

this.$().on('change', (event) => { this.handleChange(event); });
},

willDestroyElement (...args) {
this._super(...args);

this.$().off('change');
},

handleChange (event) {
const input = event.target;
if (!Ember.isEmpty(input.files)) {
this.trigger('filesDidChange', input.files);
Expand Down
3 changes: 2 additions & 1 deletion addon/uploaders/base.js
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,8 @@ export default Ember.Object.extend(Ember.Evented, {
}
}

if (files.constructor === FileList) {
// if is a array of files ...
if (files.constructor === FileList || files.constructor === Array) {
const paramKey = `${this.toNamespacedParam(this.paramName)}[]`;

for (let i = 0; i < files.length; i++) {
Expand Down
4 changes: 2 additions & 2 deletions addon/uploaders/s3.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ export default Uploader.extend({
/**
* Request signed upload policy and upload file(s) and any extra data
*
* @param {object|array} files One file object or one array of files object
* @param {object} file A file object
* @param {object} extra Extra data to be sent with the upload
* @return {object} Returns a Ember.RSVP.Promise wrapping the signing
* request object
Expand Down Expand Up @@ -61,7 +61,7 @@ export default Uploader.extend({
/**
* Request signed upload policy
*
* @param {object|array} files One file object or one array of files object
* @param {object} file A file object
* @param {object} extra Extra data to be sent with the upload
* @return {object} Returns a Ember.RSVP.Promise wrapping the signing
* request object
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"title": "Ember Uploader",
"name": "ember-uploader",
"version": "1.2.2",
"version": "1.2.3",
"description": "Ember.js addon to facilitate uploading",
"homepage": "https://github.com/benefitcloud/ember-uploader",
"license": "MIT",
Expand Down
2 changes: 1 addition & 1 deletion tests/dummy/app/mirage/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import Mirage from 'ember-cli-mirage';

export default function() {
this.get('/sign', { bucket: 'testbucket' });
this.post('http://testbucket.s3.amazonaws.com');
this.post('http://testbucket.s3.amazonaws.com', { message: 'OK' }, 201);
this.post('/upload', { message: 'OK' }, 201);
this.post('/invalid', { message: 'Not Found' }, 404);
}
102 changes: 102 additions & 0 deletions tests/integration/components/file-field-test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
import { moduleForComponent, test } from 'ember-qunit';
import hbs from 'htmlbars-inline-precompile';
import sinon from 'sinon';
import jQuery from 'jquery';


moduleForComponent('file-field', 'Integration | Component | file field', {
integration: true
});

function fillInFileInput(selector, file) {
// Get the input
let input = jQuery(selector);

// Get out file options
let { fileName, type, content } = file;

// Create a custom event for change and inject target
let event = jQuery.Event('change', {
target: { files: [{ fileName, type }] }
});

// Trigger event
input.trigger(event);
}

test('renders input with multiple attributes', function(assert) {
assert.expect(7);

this.render(hbs`{{file-field
type='file'
disabled=true
name='My name'
autofocus=true
required=true
multiple=true
form='formId'
accept='audio/*|video/*|image/*'
}}`);

assert.equal(
this.$('input').attr('disabled'),
'disabled',
'File field is disabled'
);

assert.equal(
this.$('input').attr('name'),
'My name',
'File field has name'
);

assert.equal(
this.$('input').attr('autofocus'),
'autofocus',
'File field has autofocus'
);

assert.equal(
this.$('input').attr('required'),
'required',
'File field has required'
);

assert.equal(
this.$('input').attr('multiple'),
'multiple',
'File field has multiple'
);

assert.equal(
this.$('input').attr('form'),
'formId',
'File field is associated with a form'
);

assert.equal(
this.$('input').attr('accept'),
'audio/*|video/*|image/*',
'File field accept types as: audio, video and image'
);

});

test('file upload works correcly', function(assert) {
let filesDidChange = sinon.spy();

let fileName = 'surprise.png';
let content = '-surprises-here';
let type = 'image/png';


this.set('filesDidChange', filesDidChange);
this.render(hbs`
{{file-field id="file-input" filesDidChange=filesDidChange}}
`);

fillInFileInput('#file-input', { fileName, content, type });

assert.ok(filesDidChange.calledOnce, 'Hook `filesDidChange` should be called once.');
assert.ok(filesDidChange.calledWithExactly([{fileName, type}]), 'Hook `filesDidChange` should be called with exact arguments');
});
2 changes: 1 addition & 1 deletion tests/unit/file-field-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ test('it triggers `filesDidChange` on change', () => {
result = files;
}
}).create();
fileField.change({ target: { files: [ 'foo' ] }});
fileField.handleChange({ target: { files: [ 'foo' ] }});

deepEqual(result, [ 'foo' ], 'it returns the files that changed');
});