mirror of
https://github.com/ets-cfuhrman-pfe/EvalueTonSavoir.git
synced 2025-08-11 21:23:54 -04:00
getOwner test
This commit is contained in:
parent
e2d4582ccf
commit
ea656fe9c7
1 changed files with 36 additions and 84 deletions
|
|
@ -64,101 +64,53 @@ describe('Folders', () => {
|
|||
});
|
||||
});
|
||||
|
||||
// beforeEach(() => {
|
||||
// jest.clearAllMocks(); // Clear any previous mock calls
|
||||
|
||||
// // Mock the collection object
|
||||
// collection = {
|
||||
// findOne: jest.fn(),
|
||||
// insertOne: jest.fn(),
|
||||
// find: jest.fn().mockReturnValue({ toArray: jest.fn() }), // Mock the find method
|
||||
// deleteOne: jest.fn(),
|
||||
// deleteMany: jest.fn(),
|
||||
// updateOne: jest.fn(),
|
||||
// };
|
||||
// getUserFolders
|
||||
describe('getUserFolders', () => {
|
||||
it('should return all folders for a user', async () => {
|
||||
const userId = '12345';
|
||||
const userFolders = [
|
||||
{ title: 'Folder 1', userId },
|
||||
{ title: 'Folder 2', userId },
|
||||
];
|
||||
// Ensure the folders do not exist before the test
|
||||
await database.collection('folders').deleteMany({ userId });
|
||||
|
||||
// // Mock the database connection
|
||||
// db = {
|
||||
// connect: jest.fn(),
|
||||
// getConnection: jest.fn().mockReturnThis(), // Add getConnection method
|
||||
// collection: jest.fn().mockReturnValue(collection),
|
||||
// };
|
||||
// Insert the folders
|
||||
await database.collection('folders').insertMany(userFolders);
|
||||
|
||||
// quizzes = new Quizzes(db);
|
||||
// folders = new Folders(db, quizzes);
|
||||
const result = await folder.getUserFolders(userId);
|
||||
|
||||
// });
|
||||
expect(result).toEqual(userFolders);
|
||||
|
||||
// // create
|
||||
// describe('create', () => {
|
||||
// it('should create a new folder and return the new folder ID', async () => {
|
||||
// const title = 'Test Folder';
|
||||
// Clean up
|
||||
await database.collection('folders').deleteMany({ userId });
|
||||
|
||||
// // Mock the database response
|
||||
// collection.findOne.mockResolvedValue(null);
|
||||
// collection.insertOne.mockResolvedValue({ insertedId: new ObjectId() });
|
||||
});
|
||||
});
|
||||
|
||||
// const result = await folders.create(title, '12345');
|
||||
// getOwner
|
||||
describe('getOwner', () => {
|
||||
it('should return the owner of a folder', async () => {
|
||||
// userId must be 24-char hex string
|
||||
const userId = '60c72b2f9b1d8b3a4c8e4d3b';
|
||||
|
||||
// expect(db.connect).toHaveBeenCalled();
|
||||
// expect(db.collection).toHaveBeenCalledWith('folders');
|
||||
// expect(collection.findOne).toHaveBeenCalledWith({ title, userId: '12345' });
|
||||
// expect(collection.insertOne).toHaveBeenCalledWith(expect.objectContaining({ title, userId: '12345' }));
|
||||
// expect(result).toBeDefined();
|
||||
// });
|
||||
expect(userId.length).toBe(24);
|
||||
expect(/^[0-9A-Fa-f]{24}$/.test(userId)).toBe(true);
|
||||
|
||||
// // throw an error if userId is undefined
|
||||
// it('should throw an error if userId is undefined', async () => {
|
||||
// const title = 'Test Folder';
|
||||
// create the folder using the folder API
|
||||
const folderId = await folder.create('Test Folder', userId);
|
||||
|
||||
// await expect(folders.create(title, undefined)).rejects.toThrow('Missing required parameter(s)');
|
||||
const folderIdString = folderId.toString();
|
||||
|
||||
// expect(db.connect).not.toHaveBeenCalled();
|
||||
// });
|
||||
expect(folderIdString.length).toBe(24);
|
||||
expect(/^[0-9A-Fa-f]{24}$/.test(folderIdString)).toBe(true);
|
||||
|
||||
// it('should throw an error if the folder already exists', async () => {
|
||||
// const title = 'Existing Folder';
|
||||
// const userId = '66fc70bea1b9e87655cf17c9';
|
||||
const result = await folder.getOwner(folderIdString);
|
||||
|
||||
// // Mock the database response of a found folder
|
||||
// collection.findOne.mockResolvedValue(
|
||||
// // real result from mongosh
|
||||
// {
|
||||
// _id: ObjectId.createFromHexString('66fd33fd81758a882ce99aae'),
|
||||
// userId: userId,
|
||||
// title: title,
|
||||
// created_at: new Date('2024-10-02T11:52:29.797Z')
|
||||
// }
|
||||
// );
|
||||
|
||||
// await expect(folders.create(title, userId)).rejects.toThrow('Folder already exists');
|
||||
|
||||
// expect(db.connect).toHaveBeenCalled();
|
||||
// expect(db.collection).toHaveBeenCalledWith('folders');
|
||||
// expect(collection.findOne).toHaveBeenCalledWith({ title, userId: userId });
|
||||
// });
|
||||
// });
|
||||
|
||||
// // getUserFolders
|
||||
// describe('getUserFolders', () => {
|
||||
// it('should return all folders for a user', async () => {
|
||||
// const userId = '12345';
|
||||
// const userFolders = [
|
||||
// { title: 'Folder 1', userId },
|
||||
// { title: 'Folder 2', userId },
|
||||
// ];
|
||||
|
||||
// // Mock the database response
|
||||
// collection.find().toArray.mockResolvedValue(userFolders);
|
||||
|
||||
// const result = await folders.getUserFolders(userId);
|
||||
|
||||
// expect(db.connect).toHaveBeenCalled();
|
||||
// expect(db.collection).toHaveBeenCalledWith('folders');
|
||||
// expect(collection.find).toHaveBeenCalledWith({ userId });
|
||||
// expect(result).toEqual(userFolders);
|
||||
// });
|
||||
// });
|
||||
expect(result).toBe(userId);
|
||||
});
|
||||
});
|
||||
|
||||
// // getOwner
|
||||
// describe('getOwner', () => {
|
||||
|
|
|
|||
Loading…
Reference in a new issue