Skip to content
This repository was archived by the owner on Jan 23, 2025. It is now read-only.
Merged
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
55 changes: 37 additions & 18 deletions test/test.register_member.js
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,9 @@ describe('Test Register Member API', function () {
* This is needed for cleaning up LDAP users because the key is the user id
* which is generated by the user sequence.
*/
var firstUserIdInLDAP = 0;
var lastUserIdInLDAP = 0;
var firstUserIdInLDAP = 0,
lastUserIdInLDAP = 0,
validateDatabase;
/**
* Clear database
* @param {Function<err>} done the callback
Expand All @@ -46,18 +47,18 @@ describe('Test Register Member API', function () {
log: function () {
return null;
}
};
require('../initializers/ldapHelper').ldapHelper(api, function(){
for(var i = firstUserIdInLDAP; i <= lastUserIdInLDAP; i++){
api.ldapHelper.removeMemberProfileLDAPEntry(""+i, function(){});
}, i;
require('../initializers/ldapHelper').ldapHelper(api, function () {
for (i = firstUserIdInLDAP; i <= lastUserIdInLDAP; i += 1) {
api.ldapHelper.removeMemberProfileLDAPEntry(i.toString(), function () {});
}
async.waterfall([
function (cb) {
testHelper.runSqlFromJSON(SQL_DIR + "common_oltp__clean.json", cb);
}, function (cb) {
testHelper.runSqlFromJSON(SQL_DIR + "informixoltp__clean.json", cb);
}
], function(){
], function () {
done();
});
});
Expand Down Expand Up @@ -104,12 +105,12 @@ describe('Test Register Member API', function () {
done();
}
});

});

/// Check if the data are in expected structure and data
it('should return errors if inputs are spaces only', function (done) {
var text = fs.readFileSync("test/test_files/exptected_member_register_invalid_1.txt", 'utf8'),
var text = fs.readFileSync("test/test_files/expected_member_register_invalid_1.txt", 'utf8'),
expected = JSON.parse(text);

supertest(API_ENDPOINT)
Expand All @@ -125,10 +126,28 @@ describe('Test Register Member API', function () {
});
});

/// Check if the data are in expected structure and data
it('should return errors if inputs are spaces only but the firstName and lastName are allowed to have spaces', function (done) {
var text = fs.readFileSync("test/test_files/expected_member_register_invalid_5.txt", 'utf8'),
expected = JSON.parse(text);

supertest(API_ENDPOINT)
.post('/v2/users').set('Accept', 'application/json')
.send({ firstName: 'a b', lastName: 'a b', handle: ' ', email: ' ', password: '123456', country: ' ' })
.expect('Content-Type', /json/)
.expect(400)
.end(function (err, result) {
if (!err) {
assert.deepEqual(JSON.parse(result.res.text).error.details, expected, "Invalid error message");
}
done(err);
});
});


/// Check if the data are in expected structure and data
it('should return errors: invalid country, email, firstname, lastname, handle, social', function (done) {
var text = fs.readFileSync("test/test_files/exptected_member_register_invalid_2.txt", 'utf8'),
var text = fs.readFileSync("test/test_files/expected_member_register_invalid_2.txt", 'utf8'),
expected = JSON.parse(text);

supertest(API_ENDPOINT)
Expand All @@ -146,7 +165,7 @@ describe('Test Register Member API', function () {

/// Check if the data are in expected structure and data
it('should return errors: invalid handle and invalid social id', function (done) {
var text = fs.readFileSync("test/test_files/exptected_member_register_invalid_3.txt", 'utf8'),
var text = fs.readFileSync("test/test_files/expected_member_register_invalid_3.txt", 'utf8'),
expected = JSON.parse(text);

supertest(API_ENDPOINT)
Expand All @@ -164,7 +183,7 @@ describe('Test Register Member API', function () {

/// Check if the user is prevented to register without a password when not using social login
it('should return errors: no password provided when registering (no social login)', function (done) {
var text = fs.readFileSync("test/test_files/exptected_member_register_invalid_4.txt", 'utf8'),
var text = fs.readFileSync("test/test_files/expected_member_register_invalid_4.txt", 'utf8'),
expected = JSON.parse(text);

supertest(API_ENDPOINT)
Expand All @@ -181,16 +200,16 @@ describe('Test Register Member API', function () {
});

//validateDatabase for test successInput
var validateDatabase = function (done) {
validateDatabase = function (done) {
var text, userExpected, securityUserExpected, userGroupExpected, userSocialExpected;

text = fs.readFileSync("test/test_files/exptected_member_register_validate_user.txt", 'utf8');
text = fs.readFileSync("test/test_files/expected_member_register_validate_user.txt", 'utf8');
userExpected = JSON.parse(text);
text = fs.readFileSync("test/test_files/exptected_member_register_validate_security_user.txt", 'utf8');
text = fs.readFileSync("test/test_files/expected_member_register_validate_security_user.txt", 'utf8');
securityUserExpected = JSON.parse(text);
text = fs.readFileSync("test/test_files/exptected_member_register_validate_user_group.txt", 'utf8');
text = fs.readFileSync("test/test_files/expected_member_register_validate_user_group.txt", 'utf8');
userGroupExpected = JSON.parse(text);
text = fs.readFileSync("test/test_files/exptected_member_register_validate_user_social.txt", 'utf8');
text = fs.readFileSync("test/test_files/expected_member_register_validate_user_social.txt", 'utf8');
userSocialExpected = JSON.parse(text);

async.series({
Expand Down Expand Up @@ -337,7 +356,7 @@ describe('Test Register Member API', function () {

/// Check if the data are in expected structure and data
it('should return if handle and email(case-insensitive) exists', function (done) {
var text = fs.readFileSync("test/test_files/exptected_member_register_invalid_existing.txt", 'utf8'),
var text = fs.readFileSync("test/test_files/expected_member_register_invalid_existing.txt", 'utf8'),
expected = JSON.parse(text);

supertest(API_ENDPOINT)
Expand Down
5 changes: 5 additions & 0 deletions test/test_files/expected_member_register_invalid_5.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
[
"Country name is not valid.",
"Email is required",
"Handle is required"
]