forked from CodeForPoznan/alinka-electron
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'CodeForPoznan#121' of github.com:Maciek246/alinka-elect…
…ron into CodeForPoznan#121
- Loading branch information
Showing
12 changed files
with
169 additions
and
100 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
const SchoolType = require("./school_type"); | ||
const School = require("./school"); | ||
|
||
module.exports = { | ||
SchoolType, | ||
School | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
const Sequelize = require("sequelize"); | ||
const { DataTypes } = require("sequelize"); | ||
|
||
const sequelize = require("../db_config").sequelize; | ||
|
||
const School = sequelize.define( | ||
"School", | ||
{ | ||
id: { | ||
type: Sequelize.INTEGER, | ||
unique: true, | ||
autoIncrement: true, | ||
primaryKey: true | ||
}, | ||
name: { | ||
type: Sequelize.STRING(80), | ||
allowNull: false | ||
}, | ||
city: { | ||
type: Sequelize.STRING(80), | ||
allowNull: false | ||
}, | ||
postCode: { | ||
type: Sequelize.STRING(6), | ||
allowNull: false, | ||
validate: { | ||
isValidaPolishPostCode(value) { | ||
const regex = /^[0-9]{2}-[0-9]{3}$/; | ||
if (!regex.test(value)) throw new Error("Invalid polish postal code"); | ||
} | ||
} | ||
}, | ||
postOffice: { | ||
type: Sequelize.STRING(80), | ||
allowNull: false | ||
}, | ||
street: { | ||
type: Sequelize.STRING(80), | ||
allowNull: false | ||
}, | ||
address: { | ||
type: Sequelize.VIRTUAL(DataTypes.STRING, ["city", "street"]), | ||
get() { | ||
return `${this.getDataValue("city")}, ${this.getDataValue("street")}`; | ||
} | ||
}, | ||
post: { | ||
type: Sequelize.VIRTUAL(DataTypes.STRING, ["postCode", "postOffice"]), | ||
get() { | ||
const { postOffice, city, postCode } = this; | ||
const postLocation = postOffice === city ? city : postOffice; | ||
return `${postCode} ${postLocation}`; | ||
} | ||
} | ||
}, | ||
{ | ||
// options | ||
} | ||
); | ||
|
||
module.exports = School; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
const Sequelize = require("sequelize"); | ||
const sequelize = require("../db_config").sequelize; | ||
const School = require("./school"); | ||
|
||
const SchoolType = sequelize.define( | ||
"SchoolType", | ||
{ | ||
name: { | ||
type: Sequelize.STRING(80), | ||
allowNull: false, | ||
unique: true, | ||
primaryKey: true | ||
} | ||
}, | ||
{ | ||
// options | ||
} | ||
); | ||
|
||
SchoolType.hasMany(School, { foreignKey: { allowNull: false } }); | ||
|
||
module.exports = SchoolType; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,14 @@ | ||
const { SchoolType } = require("../../db/models"); | ||
const SchoolType = require("../../db/models/school_type"); | ||
const schoolTypeList = require("../../db/school_types"); | ||
const faker = require("faker/locale/pl"); | ||
|
||
const schoolTypeData = () => { | ||
return faker.random.arrayElement(schoolTypeList); | ||
}; | ||
|
||
const schoolTypeFixture = async name => | ||
await SchoolType.create({ name: name || schoolTypeData() }); | ||
const schoolTypeFixture = async name => { | ||
return await SchoolType.create({ name: name || schoolTypeData() }); | ||
}; | ||
|
||
module.exports = schoolTypeFixture; | ||
module.exports.schoolTypeData = schoolTypeData; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,36 +1,61 @@ | ||
const { sequelize } = require("../../db/db_config"); | ||
const schoolFactory = require("../factories/schoolFactory"); | ||
const {schoolData} = require("../factories/schoolFactory"); | ||
const schoolTypeFactory = require("../factories/schoolTypeFactory"); | ||
const truncate = require("../truncate"); | ||
const { School, SchoolType } = require("../../db/models"); | ||
const { schoolData } = require("../factories/schoolFactory"); | ||
const { School } = require("../../db/models"); | ||
|
||
describe("School model", () => { | ||
|
||
beforeEach(async () => { | ||
await truncate([School, SchoolType]); | ||
await schoolTypeFactory("przedszkole") | ||
beforeEach(() => { | ||
return sequelize | ||
.sync({ force: true }) | ||
.then(() => schoolTypeFactory("mock")); | ||
}); | ||
afterEach(async () => { | ||
await truncate([School, SchoolType]); | ||
|
||
afterAll(async () => { | ||
await sequelize.drop(); | ||
}); | ||
|
||
it("should be created", async () => { | ||
const school = await sequelize | ||
.sync({ force: true }) | ||
.then(() => schoolFactory({ name: "TEST", type: "przedszkole" })); | ||
const school = await School.create({ ...schoolData("mock"), name: "TEST" }); | ||
|
||
expect(school).toBeTruthy(); | ||
expect(school.dataValues.name).toBe("TEST"); | ||
expect(school.name).toEqual("TEST"); | ||
}); | ||
|
||
it("should return concatenated data by calling `address`", async () => { | ||
it("should validate `postCode`", async () => { | ||
const school = await sequelize | ||
.sync({ force: true }) | ||
.then(() => schoolFactory({ street: "TEST STREET", type: "przedszkole" })); | ||
|
||
expect(school).toBeTruthy(); | ||
expect(school.dataValues.address).toBe("TEST STREET"); | ||
.then(() => | ||
schoolFactory({ | ||
type: "mock", | ||
postCode: "invalid code", | ||
SchoolTypeName: "mock" | ||
}) | ||
) | ||
.catch(err => err.message); | ||
|
||
expect(school).toEqual("Validation error: Invalid polish postal code"); | ||
}); | ||
|
||
describe("has virtual methods which", () => { | ||
it("return concatenated address data by calling `address`", async () => { | ||
const school = await schoolFactory({ | ||
street: "Testowa 2", | ||
city: "Poznan", | ||
SchoolTypeName: "mock" | ||
}); | ||
|
||
expect(school.address).toEqual("Poznan, Testowa 2"); | ||
}); | ||
|
||
it("return concatenated post data by calling `post`", async () => { | ||
const school = await schoolFactory({ | ||
postCode: "12-345", | ||
postOffice: "Poznan", | ||
SchoolTypeName: "mock" | ||
}); | ||
|
||
expect(school.post).toEqual("12-345 Poznan"); | ||
}); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,7 @@ | ||
module.exports = async function truncate(models) { | ||
if (models instanceof Array){ | ||
models.map( | ||
model => model.destroy({ where: {}, force: true }) | ||
); | ||
} | ||
else { | ||
if (models instanceof Array) { | ||
models.map(model => model.destroy({ where: {}, force: true })); | ||
} else { | ||
models.destroy({ where: {}, force: true }); | ||
} | ||
}; |