fix: add CouchDB mocking to all route tests
- Add comprehensive CouchDB service mocks to all route test files - Include all required service methods (find, create, update, etc.) - Add beforeEach cleanup to ensure mock state is reset - Consistent mocking pattern across all route tests 🤖 Generated with [AI Assistant] Co-Authored-By: AI Assistant <noreply@ai-assistant.com>
This commit is contained in:
@@ -1,8 +1,20 @@
|
|||||||
// Mock CouchDB service for testing
|
|
||||||
jest.mock('../../services/couchdbService');
|
|
||||||
|
|
||||||
const request = require('supertest');
|
const request = require('supertest');
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
|
|
||||||
|
// Mock CouchDB service before importing routes
|
||||||
|
jest.mock('../../services/couchdbService', () => ({
|
||||||
|
initialize: jest.fn().mockResolvedValue(true),
|
||||||
|
create: jest.fn(),
|
||||||
|
getById: jest.fn(),
|
||||||
|
find: jest.fn(),
|
||||||
|
createDocument: jest.fn(),
|
||||||
|
updateDocument: jest.fn(),
|
||||||
|
deleteDocument: jest.fn(),
|
||||||
|
findByType: jest.fn(),
|
||||||
|
findUserById: jest.fn(),
|
||||||
|
update: jest.fn(),
|
||||||
|
}));
|
||||||
|
|
||||||
const authRoutes = require('../../routes/auth');
|
const authRoutes = require('../../routes/auth');
|
||||||
const User = require('../../models/User');
|
const User = require('../../models/User');
|
||||||
const couchdbService = require('../../services/couchdbService');
|
const couchdbService = require('../../services/couchdbService');
|
||||||
|
|||||||
@@ -1,8 +1,24 @@
|
|||||||
const request = require('supertest');
|
const request = require('supertest');
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
|
|
||||||
|
// Mock CouchDB service before importing routes
|
||||||
|
jest.mock('../../services/couchdbService', () => ({
|
||||||
|
initialize: jest.fn().mockResolvedValue(true),
|
||||||
|
create: jest.fn(),
|
||||||
|
getById: jest.fn(),
|
||||||
|
find: jest.fn(),
|
||||||
|
createDocument: jest.fn(),
|
||||||
|
updateDocument: jest.fn(),
|
||||||
|
deleteDocument: jest.fn(),
|
||||||
|
findByType: jest.fn(),
|
||||||
|
findUserById: jest.fn(),
|
||||||
|
update: jest.fn(),
|
||||||
|
}));
|
||||||
|
|
||||||
const eventsRoutes = require('../../routes/events');
|
const eventsRoutes = require('../../routes/events');
|
||||||
const Event = require('../../models/Event');
|
const Event = require('../../models/Event');
|
||||||
const { createTestUser, createTestEvent } = require('../utils/testHelpers');
|
const { createTestUser, createTestEvent } = require('../utils/testHelpers');
|
||||||
|
const couchdbService = require('../../services/couchdbService');
|
||||||
|
|
||||||
// Create Express app for testing
|
// Create Express app for testing
|
||||||
const app = express();
|
const app = express();
|
||||||
@@ -10,6 +26,9 @@ app.use(express.json());
|
|||||||
app.use('/api/events', eventsRoutes);
|
app.use('/api/events', eventsRoutes);
|
||||||
|
|
||||||
describe('Events Routes', () => {
|
describe('Events Routes', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
});
|
||||||
describe('GET /api/events', () => {
|
describe('GET /api/events', () => {
|
||||||
it('should get all events', async () => {
|
it('should get all events', async () => {
|
||||||
const { user } = await createTestUser();
|
const { user } = await createTestUser();
|
||||||
|
|||||||
@@ -1,8 +1,24 @@
|
|||||||
const request = require('supertest');
|
const request = require('supertest');
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
|
|
||||||
|
// Mock CouchDB service before importing routes
|
||||||
|
jest.mock('../../services/couchdbService', () => ({
|
||||||
|
initialize: jest.fn().mockResolvedValue(true),
|
||||||
|
create: jest.fn(),
|
||||||
|
getById: jest.fn(),
|
||||||
|
find: jest.fn(),
|
||||||
|
createDocument: jest.fn(),
|
||||||
|
updateDocument: jest.fn(),
|
||||||
|
deleteDocument: jest.fn(),
|
||||||
|
findByType: jest.fn(),
|
||||||
|
findUserById: jest.fn(),
|
||||||
|
update: jest.fn(),
|
||||||
|
}));
|
||||||
|
|
||||||
const reportsRoutes = require('../../routes/reports');
|
const reportsRoutes = require('../../routes/reports');
|
||||||
const Report = require('../../models/Report');
|
const Report = require('../../models/Report');
|
||||||
const { createTestUser, createTestStreet, createTestReport } = require('../utils/testHelpers');
|
const { createTestUser, createTestStreet, createTestReport } = require('../utils/testHelpers');
|
||||||
|
const couchdbService = require('../../services/couchdbService');
|
||||||
|
|
||||||
// Create Express app for testing
|
// Create Express app for testing
|
||||||
const app = express();
|
const app = express();
|
||||||
@@ -10,6 +26,9 @@ app.use(express.json());
|
|||||||
app.use('/api/reports', reportsRoutes);
|
app.use('/api/reports', reportsRoutes);
|
||||||
|
|
||||||
describe('Reports Routes', () => {
|
describe('Reports Routes', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
});
|
||||||
describe('GET /api/reports', () => {
|
describe('GET /api/reports', () => {
|
||||||
it('should get all reports', async () => {
|
it('should get all reports', async () => {
|
||||||
const { user } = await createTestUser();
|
const { user } = await createTestUser();
|
||||||
|
|||||||
@@ -1,9 +1,25 @@
|
|||||||
const request = require('supertest');
|
const request = require('supertest');
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
|
|
||||||
|
// Mock CouchDB service before importing routes
|
||||||
|
jest.mock('../../services/couchdbService', () => ({
|
||||||
|
initialize: jest.fn().mockResolvedValue(true),
|
||||||
|
create: jest.fn(),
|
||||||
|
getById: jest.fn(),
|
||||||
|
find: jest.fn(),
|
||||||
|
createDocument: jest.fn(),
|
||||||
|
updateDocument: jest.fn(),
|
||||||
|
deleteDocument: jest.fn(),
|
||||||
|
findByType: jest.fn(),
|
||||||
|
findUserById: jest.fn(),
|
||||||
|
update: jest.fn(),
|
||||||
|
}));
|
||||||
|
|
||||||
const rewardsRoutes = require('../../routes/rewards');
|
const rewardsRoutes = require('../../routes/rewards');
|
||||||
const Reward = require('../../models/Reward');
|
const Reward = require('../../models/Reward');
|
||||||
const User = require('../../models/User');
|
const User = require('../../models/User');
|
||||||
const { createTestUser, createTestReward } = require('../utils/testHelpers');
|
const { createTestUser, createTestReward } = require('../utils/testHelpers');
|
||||||
|
const couchdbService = require('../../services/couchdbService');
|
||||||
|
|
||||||
// Create Express app for testing
|
// Create Express app for testing
|
||||||
const app = express();
|
const app = express();
|
||||||
@@ -11,6 +27,9 @@ app.use(express.json());
|
|||||||
app.use('/api/rewards', rewardsRoutes);
|
app.use('/api/rewards', rewardsRoutes);
|
||||||
|
|
||||||
describe('Rewards Routes', () => {
|
describe('Rewards Routes', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
});
|
||||||
describe('GET /api/rewards', () => {
|
describe('GET /api/rewards', () => {
|
||||||
it('should get all rewards', async () => {
|
it('should get all rewards', async () => {
|
||||||
await createTestReward({ name: 'Reward 1', pointsCost: 50 });
|
await createTestReward({ name: 'Reward 1', pointsCost: 50 });
|
||||||
|
|||||||
@@ -1,13 +1,32 @@
|
|||||||
const request = require('supertest');
|
const request = require('supertest');
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
|
|
||||||
|
// Mock CouchDB service before importing routes
|
||||||
|
jest.mock('../../services/couchdbService', () => ({
|
||||||
|
initialize: jest.fn().mockResolvedValue(true),
|
||||||
|
create: jest.fn(),
|
||||||
|
getById: jest.fn(),
|
||||||
|
find: jest.fn(),
|
||||||
|
createDocument: jest.fn(),
|
||||||
|
updateDocument: jest.fn(),
|
||||||
|
deleteDocument: jest.fn(),
|
||||||
|
findByType: jest.fn(),
|
||||||
|
findUserById: jest.fn(),
|
||||||
|
update: jest.fn(),
|
||||||
|
}));
|
||||||
|
|
||||||
const streetRoutes = require('../../routes/streets');
|
const streetRoutes = require('../../routes/streets');
|
||||||
const { createTestUser, createTestStreet } = require('../utils/testHelpers');
|
const { createTestUser, createTestStreet } = require('../utils/testHelpers');
|
||||||
|
const couchdbService = require('../../services/couchdbService');
|
||||||
|
|
||||||
const app = express();
|
const app = express();
|
||||||
app.use(express.json());
|
app.use(express.json());
|
||||||
app.use('/api/streets', streetRoutes);
|
app.use('/api/streets', streetRoutes);
|
||||||
|
|
||||||
describe('Street Routes', () => {
|
describe('Street Routes', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
});
|
||||||
describe('GET /api/streets', () => {
|
describe('GET /api/streets', () => {
|
||||||
it('should get all streets', async () => {
|
it('should get all streets', async () => {
|
||||||
const { user } = await createTestUser();
|
const { user } = await createTestUser();
|
||||||
|
|||||||
@@ -1,13 +1,32 @@
|
|||||||
const request = require('supertest');
|
const request = require('supertest');
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
|
|
||||||
|
// Mock CouchDB service before importing routes
|
||||||
|
jest.mock('../../services/couchdbService', () => ({
|
||||||
|
initialize: jest.fn().mockResolvedValue(true),
|
||||||
|
create: jest.fn(),
|
||||||
|
getById: jest.fn(),
|
||||||
|
find: jest.fn(),
|
||||||
|
createDocument: jest.fn(),
|
||||||
|
updateDocument: jest.fn(),
|
||||||
|
deleteDocument: jest.fn(),
|
||||||
|
findByType: jest.fn(),
|
||||||
|
findUserById: jest.fn(),
|
||||||
|
update: jest.fn(),
|
||||||
|
}));
|
||||||
|
|
||||||
const taskRoutes = require('../../routes/tasks');
|
const taskRoutes = require('../../routes/tasks');
|
||||||
const { createTestUser, createTestStreet, createTestTask } = require('../utils/testHelpers');
|
const { createTestUser, createTestStreet, createTestTask } = require('../utils/testHelpers');
|
||||||
|
const couchdbService = require('../../services/couchdbService');
|
||||||
|
|
||||||
const app = express();
|
const app = express();
|
||||||
app.use(express.json());
|
app.use(express.json());
|
||||||
app.use('/api/tasks', taskRoutes);
|
app.use('/api/tasks', taskRoutes);
|
||||||
|
|
||||||
describe('Task Routes', () => {
|
describe('Task Routes', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
});
|
||||||
describe('GET /api/tasks', () => {
|
describe('GET /api/tasks', () => {
|
||||||
it('should get all tasks completed by authenticated user', async () => {
|
it('should get all tasks completed by authenticated user', async () => {
|
||||||
const { user, token } = await createTestUser();
|
const { user, token } = await createTestUser();
|
||||||
|
|||||||
Reference in New Issue
Block a user