
================================================================================
Test Case #1
================================================================================

================================================================================
Test Case ID: 1
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Helper function to read JSON data from a file
function readJSONFile(filePath) {
  return new Promise((resolve, reject) => {
    fs.readFile(filePath, 'utf8', (err, data) => {
      if (err) {
        reject(err);
      } else {
        try {
          const jsonData = JSON.parse(data);
          resolve(jsonData);
        } catch (parseErr) {
          reject(parseErr);
        }
      }
    });
  });
}

// Helper function to write JSON data to a file
function writeJSONFile(filePath, jsonData) {
  return new Promise((resolve, reject) => {
    const data = JSON.stringify(jsonData, null, 2);
    fs.writeFile(filePath, data, 'utf8', (err) => {
      if (err) {
        reject(err);
      } else {
        resolve();
      }
    });
  });
}

const logFilePath = path.join(__dirname, 'log.json');

// Initial log data
const initialLogData = { logs: [] };

// Write initial log data to file
writeJSONFile(logFilePath, initialLogData).then(() => {
  console.log('Initial log data written.');
}).catch(err => {
  console.error('Error writing initial log data:', err);
});

// Function to log an event
function logEvent(event) {
  return readJSONFile(logFilePath)
    .then(data => {

GOLDEN COMPLETION:
----------------------------------------
      data.logs.push(event);
      return writeJSONFile(logFilePath, data);

SUFFIX CODE:
----------------------------------------
    })
    .then(() => {
      console.log('Event logged:', event);
    })
    .catch(err => {
      console.error('Error logging event:', err);
    });
}

// Example usage
logEvent({ type: 'ERROR', message: 'An error occurred', timestamp: new Date().toISOString() });

// Assertions
readJSONFile(logFilePath).then(data => {
  const lastLog = data.logs[data.logs.length - 1];
  console.assert(lastLog.type === 'ERROR', 'Expected log type to be ERROR');
  console.assert(lastLog.message === 'An error occurred', 'Expected log message to be "An error occurred"');
  console.assert(new Date(lastLog.timestamp).toString() !== 'Invalid Date', 'Expected valid timestamp');
}).catch(err => {
  console.error('Assertion error:', err);
});


JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to understand the business logic of logging events to a JSON file and appropriately handle asynchronous file operations using Promises. The prefix sets up the necessary functions for reading and writing JSON data and demonstrates initial file writing. The golden completion involves adding an event to the log and writing the updated log back to the file, which is crucial for maintaining the correctness of the log system. The suffix continues by demonstrating the expected behavior after the completion, and the assertions verify that the logging functionality behaves as intended, ensuring the semantic understanding of the process.

ASSERTIONS:
----------------------------------------
readJSONFile(logFilePath).then(data => {
  const lastLog = data.logs[data.logs.length - 1];
  console.assert(lastLog.type === 'ERROR', 'Expected log type to be ERROR');
  console.assert(lastLog.message === 'An error occurred', 'Expected log message to be "An error occurred"');
  console.assert(new Date(lastLog.timestamp).toString() !== 'Invalid Date', 'Expected valid timestamp');
}).catch(err => {
  console.error('Assertion error:', err);
});

================================================================================

================================================================================
Test Case #2
================================================================================

================================================================================
Test Case ID: 2
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// This function reads a JSON file, processes the data and logs specific metrics
async function processMetrics(filePath) {
    try {
        // Read the file
        const data = await fs.promises.readFile(filePath, 'utf-8');
        const jsonData = JSON.parse(data);

        // Calculate metrics
        const totalUsers = jsonData.users.length;
        const activeUsers = jsonData.users.filter(user => user.active).length;

        // Log metrics
        console.log(`Total Users: ${totalUsers}`);
        console.log(`Active Users: ${activeUsers}`);

        // Now we need to calculate the average age of users
        const totalAge = jsonData.users.reduce((sum, user) => sum + user.age, 0);

GOLDEN COMPLETION:
----------------------------------------

        const averageAge = totalAge / totalUsers;
        console.log(`Average Age: ${averageAge.toFixed(2)}`);

SUFFIX CODE:
----------------------------------------

    } catch (error) {
        console.error('Error processing metrics:', error);
    }
}

// Example JSON data for testing
const testFilePath = path.join(__dirname, 'testData.json');
const testData = {
    users: [
        { name: 'Alice', age: 30, active: true },
        { name: 'Bob', age: 25, active: false },
        { name: 'Charlie', age: 35, active: true }
    ]
};
fs.writeFileSync(testFilePath, JSON.stringify(testData));

// Run the function
processMetrics(testFilePath).then(() => {
    // Clean up test file
    fs.unlinkSync(testFilePath);
});

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand and continue a function that processes JSON data, calculates metrics, and logs them. The golden completion involves calculating the average age of users, which requires understanding the business logic of summing user ages and dividing by the total number of users. The suffix code is different and continues the process without repeating the golden completion. Assertions verify the correctness of the metrics calculations.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

async function testProcessMetrics() {
    const testFilePath = path.join(__dirname, 'testData.json');
    const testData = {
        users: [
            { name: 'Alice', age: 30, active: true },
            { name: 'Bob', age: 25, active: false },
            { name: 'Charlie', age: 35, active: true }
        ]
    };
    fs.writeFileSync(testFilePath, JSON.stringify(testData));

    let consoleOutput = [];
    const originalConsoleLog = console.log;
    console.log = (output) => consoleOutput.push(output);

    await processMetrics(testFilePath);

    // Restore original console.log function
    console.log = originalConsoleLog;

    assert(consoleOutput.includes('Total Users: 3'));
    assert(consoleOutput.includes('Active Users: 2'));
    assert(consoleOutput.includes('Average Age: 30.00'));

    // Clean up test file
    fs.unlinkSync(testFilePath);
}

testProcessMetrics().then(() => {
    console.log('All assertions passed.');
}).catch(error => {
    console.error('An assertion failed:', error);
});
================================================================================

================================================================================
Test Case #3
================================================================================

================================================================================
Test Case ID: 3
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

class Authentication {
    constructor() {
        this.users = {};
    }

    // Function to create a new user with hashed password
    createUser(username, password) {
        if(this.users[username]) {
            throw new Error('User already exists');
        }
        const hashedPassword = this.hashPassword(password);
        this.users[username] = hashedPassword;
    }

    // Function to hash a password
    hashPassword(password) {
        const salt = crypto.randomBytes(16).toString('hex');
        const hash = crypto.pbkdf2Sync(password, salt, 1000, 64, 'sha512').toString('hex');
        return { salt, hash };
    }

    // Function to verify a user's password
    verifyPassword(username, password) {
        const user = this.users[username];
        if (!user) {
            throw new Error('User does not exist');
        }
        const { salt, hash } = user;


GOLDEN COMPLETION:
----------------------------------------
        const hashedInputPassword = crypto.pbkdf2Sync(password, salt, 1000, 64, 'sha512').toString('hex');
        return hashedInputPassword === hash;


SUFFIX CODE:
----------------------------------------

    }
}

const auth = new Authentication();
auth.createUser('testuser', 'testpassword');

// Test valid login
console.assert(auth.verifyPassword('testuser', 'testpassword') === true, 'Password should be valid');

// Test invalid login
console.assert(auth.verifyPassword('testuser', 'wrongpassword') === false, 'Password should be invalid');

// Test non-existent user
try {
    auth.verifyPassword('nonuser', 'somepassword');
} catch (error) {
    console.assert(error.message === 'User does not exist', 'Error message should indicate non-existent user');
}

console.log('All assertions passed.');

JUSTIFICATION:
----------------------------------------
This is a good test case because it evaluates the LLM's understanding of security practices in user authentication, specifically the process of hashing passwords and verifying them. The completion requires knowledge of how to correctly hash the input password with the stored salt and compare it to the stored hash, which is critical in many security applications. The provided assertions test various scenarios such as correct password, incorrect password, and non-existent users, ensuring the completion correctly implements the intended logic.

ASSERTIONS:
----------------------------------------
const auth = new Authentication();
auth.createUser('testuser', 'testpassword');

// Test valid login
console.assert(auth.verifyPassword('testuser', 'testpassword') === true, 'Password should be valid');

// Test invalid login
console.assert(auth.verifyPassword('testuser', 'wrongpassword') === false, 'Password should be invalid');

// Test non-existent user
try {
    auth.verifyPassword('nonuser', 'somepassword');
} catch (error) {
    console.assert(error.message === 'User does not exist', 'Error message should indicate non-existent user');
}

console.log('All assertions passed.');
================================================================================

================================================================================
Test Case #4
================================================================================

================================================================================
Test Case ID: 4
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');

class Logger {
  constructor(logFilePath) {
    this.logFilePath = logFilePath;
  }

  async logMessage(message) {
    const logEntry = `${new Date().toISOString()} - ${message}\n`;
    await fs.promises.appendFile(this.logFilePath, logEntry);
  }
}

const logger = new Logger('system.log');

async function monitorSystem() {
  try {
    const cpuLoad = await getCPULoad();
    const memoryUsage = await getMemoryUsage();
    await logger.logMessage(`CPU Load: ${cpuLoad}%`);
    await logger.logMessage(`Memory Usage: ${memoryUsage} MB`);

    if (cpuLoad > 80) {
      // High CPU load detected
      await logger.logMessage('Warning: High CPU load detected');
    }


GOLDEN COMPLETION:
----------------------------------------
    if (memoryUsage > 1024) {
      // High memory usage detected
      await logger.logMessage('Warning: High memory usage detected');
    }


SUFFIX CODE:
----------------------------------------
  } catch (error) {
    await logger.logMessage(`Error: ${error.message}`);
  }
}

function getCPULoad() {
  return new Promise((resolve) => {
    setTimeout(() => {
      resolve(75); // Mocked CPU load
    }, 100);
  });
}

function getMemoryUsage() {
  return new Promise((resolve) => {
    setTimeout(() => {
      resolve(2048); // Mocked Memory usage in MB
    }, 100);
  });
}

monitorSystem().then(() => {
  fs.promises.readFile('system.log', 'utf8').then((data) => {
    console.log(data);
  });
});


JUSTIFICATION:
----------------------------------------
This test case is designed to assess the understanding of async-await patterns combined with system monitoring and logging. The goal is to ensure the logger captures high CPU and memory usage, which is critical for system operations. The completion requires the model to correctly identify and log high memory usage, following the same pattern used for logging CPU load.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const logContent = fs.readFileSync('system.log', 'utf8');

assert(logContent.includes('CPU Load: 75%'), 'CPU load should be logged');
assert(logContent.includes('Memory Usage: 2048 MB'), 'Memory usage should be logged');
assert(logContent.includes('Warning: High memory usage detected'), 'High memory usage warning should be logged');

================================================================================

================================================================================
Test Case #5
================================================================================

================================================================================
Test Case ID: 5
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

// Function to encrypt a text using a secret key
function encryptText(text, secretKey) {
    const algorithm = 'aes-256-cbc';
    const iv = crypto.randomBytes(16);
    const cipher = crypto.createCipheriv(algorithm, secretKey, iv);
    let encrypted = cipher.update(text, 'utf8', 'hex');
    encrypted += cipher.final('hex');
    return { iv: iv.toString('hex'), encryptedData: encrypted };
}

// Function to decrypt a text using a secret key
function decryptText(encryptedText, secretKey) {
    const algorithm = 'aes-256-cbc';
    const iv = Buffer.from(encryptedText.iv, 'hex');
    const encryptedData = encryptedText.encryptedData;
    const decipher = crypto.createDecipheriv(algorithm, secretKey, iv);
    let decrypted = decipher.update(encryptedData, 'hex', 'utf8');
    decrypted += decipher.final('utf8');
    return decrypted;
}

// Example usage of the encryption and decryption functions
const secretKey = crypto.randomBytes(32);
const textToEncrypt = 'Sensitive data to be encrypted';
const encryptedText = encryptText(textToEncrypt, secretKey);
const decryptedText = 

GOLDEN COMPLETION:
----------------------------------------
decryptText(encryptedText, secretKey);

SUFFIX CODE:
----------------------------------------
decryptText({ iv: encryptedText.iv, encryptedData: 'incorrect_data' }, secretKey);

try {
    const decryptedText = decryptText(encryptedText, secretKey);
    console.log('Decrypted text:', decryptedText);
} catch (error) {
    console.error('Failed to decrypt:', error.message);
}


JUSTIFICATION:
----------------------------------------
This test case demonstrates the use of encryption and decryption functions for handling sensitive data, which is a common requirement in security domains. The golden_completion correctly uses the decryptText function to decrypt previously encrypted text, maintaining the logical flow and ensuring data integrity. This tests the LLM's understanding of security patterns, error handling, and proper usage of cryptographic functions. Assertions verify that the decrypted text matches the original input, confirming functional and semantic correctness.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
assert.strictEqual(decryptedText, textToEncrypt, 'The decrypted text should match the original text to ensure data integrity.');

================================================================================

================================================================================
Test Case #6
================================================================================

================================================================================
Test Case ID: 6
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const axios = require('axios');

class NetworkMonitor {
    constructor(apiUrl) {
        this.apiUrl = apiUrl;
        this.log = [];
    }

    async fetchData(endpoint) {
        try {
            const response = await axios.get(`${this.apiUrl}/${endpoint}`);
            this.log.push({ endpoint, status: response.status });
            return response.data;
        } catch (error) {
            this.log.push({ endpoint, status: 'error', message: error.message });
            throw error;
        }
    }
}

// Instantiate the NetworkMonitor class
const monitor = new NetworkMonitor('https://api.example.com');

// Fetch data from the 'status' endpoint
(async () => {
    try {

GOLDEN COMPLETION:
----------------------------------------
        const data = await monitor.fetchData('status');

SUFFIX CODE:
----------------------------------------
        console.log('Data:', data);
    } catch (error) {
        console.error('Error fetching data:', error.message);
    }

    // Assertions
    console.assert(monitor.log.length === 1, 'Log should have one entry');
    console.assert(monitor.log[0].endpoint === 'status', 'Log entry should be for the status endpoint');
    console.assert(monitor.log[0].status === 200, 'Status should be 200');
})();


JUSTIFICATION:
----------------------------------------
This example tests understanding of promises/async-await in the context of a network monitoring system. The completion should correctly use the fetchData method to fetch data from a specific endpoint and handle the response or error appropriately. The assertions check that the log is correctly populated with the endpoint and status.

ASSERTIONS:
----------------------------------------
console.assert(monitor.log.length === 1, 'Log should have one entry');
console.assert(monitor.log[0].endpoint === 'status', 'Log entry should be for the status endpoint');
console.assert(monitor.log[0].status === 200, 'Status should be 200');
================================================================================

================================================================================
Test Case #7
================================================================================

================================================================================
Test Case ID: 7
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

class Logger {
    constructor(logFilePath) {
        this.logFilePath = logFilePath;
    }

    log(message) {
        const timestamp = new Date().toISOString();
        const logMessage = `${timestamp} - ${message}\n`;
        fs.appendFileSync(this.logFilePath, logMessage);
    }
}

class SystemMonitor {
    constructor(logger) {
        this.logger = logger;
        this.metrics = [];
    }

    recordMetric(metric) {
        this.metrics.push(metric);
        this.logger.log(`Recorded metric: ${JSON.stringify(metric)}`);
    }

    generateReport() {
        const report = this.metrics.reduce((acc, metric) => {
            acc.total += metric.value;
            acc.count += 1;
            return acc;
        }, { total: 0, count: 0 });
        report.average = report.total / report.count;
        return report;
    }

    saveReport(reportFilePath) {
        const report = this.generateReport();
        const reportContent = `Total: ${report.total}, Count: ${report.count}, Average: ${report.average}\n`;
        fs.writeFileSync(reportFilePath, reportContent);
    }
}

// Setup
const logFilePath = path.join(__dirname, 'system.log');
const reportFilePath = path.join(__dirname, 'report.txt');
const logger = new Logger(logFilePath);
const systemMonitor = new SystemMonitor(logger);

// Record some metrics
systemMonitor.recordMetric({ type: 'cpu', value: 75 });
systemMonitor.recordMetric({ type: 'memory', value: 60 });
systemMonitor.recordMetric({ type: 'disk', value: 90 });

// Save the report

GOLDEN COMPLETION:
----------------------------------------
systemMonitor.saveReport(reportFilePath);

SUFFIX CODE:
----------------------------------------
// Assertions
const assert = require('assert');
const reportContent = fs.readFileSync(reportFilePath, 'utf8');
assert(reportContent.includes('Total: 225'));
assert(reportContent.includes('Count: 3'));
assert(reportContent.includes('Average: 75'));

const logContent = fs.readFileSync(logFilePath, 'utf8');
assert(logContent.includes('Recorded metric: {"type":"cpu","value":75}'));
assert(logContent.includes('Recorded metric: {"type":"memory","value":60}'));
assert(logContent.includes('Recorded metric: {"type":"disk","value":90}'));

// Cleanup
fs.unlinkSync(logFilePath);
fs.unlinkSync(reportFilePath);

JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to understand and correctly continue code that involves system monitoring and logging, a common scenario in system operations. The golden completion requires the model to correctly call a method that generates and saves a report, demonstrating comprehension of the business logic and domain context. The assertions verify that the report and log files contain the expected content, ensuring the semantic correctness of the completion.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const reportContent = fs.readFileSync(reportFilePath, 'utf8');
assert(reportContent.includes('Total: 225'));
assert(reportContent.includes('Count: 3'));
assert(reportContent.includes('Average: 75'));

const logContent = fs.readFileSync(logFilePath, 'utf8');
assert(logContent.includes('Recorded metric: {"type":"cpu","value":75}'));
assert(logContent.includes('Recorded metric: {"type":"memory","value":60}'));
assert(logContent.includes('Recorded metric: {"type":"disk","value":90}'));

// Cleanup
fs.unlinkSync(logFilePath);
fs.unlinkSync(reportFilePath);
================================================================================

================================================================================
Test Case #8
================================================================================

================================================================================
Test Case ID: 8
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');

// Function to analyze log file entries and generate a report
class LogAnalyzer {
    constructor(filePath) {
        this.filePath = filePath;
    }

    async readLogFile() {
        try {
            const data = await fs.promises.readFile(this.filePath, 'utf-8');
            return data.split('\n');
        } catch (error) {
            console.error('Error reading log file:', error);
            throw error;
        }
    }

    async analyze() {
        const entries = await this.readLogFile();
        const report = this.generateReport(entries);
        return report;
    }

    generateReport(entries) {
        const report = {
            totalEntries: entries.length,
            errorCount: 0,
            warningCount: 0,
            infoCount: 0
        };
        entries.forEach(entry => {
            if (entry.includes('ERROR')) {
                report.errorCount += 1;
            } else if (entry.includes('WARNING')) {
                report.warningCount += 1;
            } else if (entry.includes('INFO')) {
                report.infoCount += 1;
            }
        });
        return report;
    }
}

// Instantiate and use LogAnalyzer
async function main() {
    const analyzer = new LogAnalyzer('system.log');
    try {
        const report = await analyzer.analyze();
        console.log('Log Analysis Report:', report);

        // Assertions
        console.assert(report.totalEntries > 0, 'There should be at least one log entry');
        console.assert(report.errorCount >= 0, 'Error count should be non-negative');
        console.assert(report.warningCount >= 0, 'Warning count should be non-negative');
        console.assert(report.infoCount >= 0, 'Info count should be non-negative');


GOLDEN COMPLETION:
----------------------------------------
        console.assert(report.totalEntries === (report.errorCount + report.warningCount + report.infoCount), 'Total entries should equal the sum of error, warning, and info counts');

SUFFIX CODE:
----------------------------------------
    } catch (error) {
        console.error('Failed to analyze logs:', error);
    }
}

main();

JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate an LLM's ability to understand the purpose and logic of a JavaScript class that analyzes log file entries to generate a report. The prefix sets up a comprehensive implementation of the LogAnalyzer class, including methods for reading log files and generating a report. The golden completion is a critical assertion that ensures the integrity of the generated report, verifying that the total number of entries matches the sum of error, warning, and info counts. This scenario tests the LLM's ability to follow the business logic and maintain consistency in the domain context of system operations and logging analysis.

ASSERTIONS:
----------------------------------------
console.assert(report.totalEntries > 0, 'There should be at least one log entry');
console.assert(report.errorCount >= 0, 'Error count should be non-negative');
console.assert(report.warningCount >= 0, 'Warning count should be non-negative');
console.assert(report.infoCount >= 0, 'Info count should be non-negative');
console.assert(report.totalEntries === (report.errorCount + report.warningCount + report.infoCount), 'Total entries should equal the sum of error, warning, and info counts');
================================================================================

================================================================================
Test Case #9
================================================================================

================================================================================
Test Case ID: 9
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// This function reads and parses a JSON file, validates its schema, and normalizes the data
function processData(filePath) {
    // Read the file content
    const fileContent = fs.readFileSync(filePath, 'utf8');
    // Parse the JSON content
    let data;
    try {
        data = JSON.parse(fileContent);
    } catch (error) {
        throw new Error('Invalid JSON format');
    }
    
    // Validate schema
    if (!data.name || !data.age || typeof data.age !== 'number') {
        throw new Error('Invalid data schema');
    }

    // Normalize data
    data.name = data.name.trim();
    if (data.age < 0) {
        data.age = 0;
    }

    return data;
}

// Example usage
const exampleFilePath = path.join(__dirname, 'example.json');


GOLDEN COMPLETION:
----------------------------------------
// Write a sample JSON file for testing
const sampleData = JSON.stringify({ name: ' John Doe ', age: 30 });
fs.writeFileSync(exampleFilePath, sampleData, 'utf8');

SUFFIX CODE:
----------------------------------------
const normalizedData = processData(exampleFilePath);

// Assertions
const assert = require('assert');
assert.strictEqual(normalizedData.name, 'John Doe');
assert.strictEqual(normalizedData.age, 30);

// Clean up
fs.unlinkSync(exampleFilePath);

JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate the LLM's ability to understand and complete code that involves data validation and normalization. The prefix sets up a function that reads, validates, and normalizes JSON data from a file. The golden completion involves writing a sample JSON file, which is necessary for the function to process during the example usage. The suffix reads the processed data, performs assertions to check if the data has been correctly normalized, and then cleans up by deleting the sample file. This scenario tests the LLM's comprehension of file handling, JSON parsing, schema validation, and data normalization within a practical context.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const fs = require('fs');
const path = require('path');

// Ensure the file exists before running assertions
assert(fs.existsSync(exampleFilePath));

// Process the data
const normalizedData = processData(exampleFilePath);

// Assertions
assert.strictEqual(normalizedData.name, 'John Doe');
assert.strictEqual(normalizedData.age, 30);

// Clean up
fs.unlinkSync(exampleFilePath);

// Ensure the file has been deleted
assert(!fs.existsSync(exampleFilePath));
================================================================================

================================================================================
Test Case #10
================================================================================

================================================================================
Test Case ID: 10
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

class LogMonitor {
    constructor(directory) {
        this.directory = directory;
        this.files = new Set();
    }

    async scanDirectory() {
        const files = await fs.promises.readdir(this.directory);
        for (const file of files) {
            if (file.endsWith('.log')) {
                this.files.add(file);
            }
        }
    }

    async readFile(file) {
        const filePath = path.join(this.directory, file);
        return await fs.promises.readFile(filePath, 'utf-8');
    }

    async monitor() {
        await this.scanDirectory();
        for (const file of this.files) {
            const content = await this.readFile(file);
            this.processLog(content);
        }
    }

    processLog(content) {
        // Placeholder for log processing logic
        console.log('Processing log:', content);
    }
}

// Usage example
const logMonitor = new LogMonitor('/var/logs');
logMonitor.monitor().catch(err => console.error('Error monitoring logs:', err));


GOLDEN COMPLETION:
----------------------------------------
logMonitor.processLog = function(content) {
    if (content.includes('ERROR')) {
        console.error('Error found in log:', content);
    } else {
        console.log('Log content:', content);
    }
};


SUFFIX CODE:
----------------------------------------


// Additional functionality could be added here
console.log('Monitoring complete.');


JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate an LLM's understanding of OOP patterns in the context of system operations, specifically log monitoring. The code demonstrates how to scan a directory for log files, read their contents, and process the logs. The completion requires modifying a method to handle specific log content, which tests comprehension of the business logic and ability to modify class methods appropriately.

ASSERTIONS:
----------------------------------------
const mockLogContent = '2023-10-12 12:34:56 ERROR Something went wrong';
logMonitor.processLog(mockLogContent);

// Capture console output
const originalConsoleError = console.error;
let errorOutput = '';
console.error = (msg) => { errorOutput += msg; };

logMonitor.processLog(mockLogContent);

// Verify the log processing behavior
console.assert(errorOutput.includes('Error found in log: 2023-10-12 12:34:56 ERROR Something went wrong'), 'Error message should be logged');

// Restore console.error
console.error = originalConsoleError;

================================================================================

================================================================================
Test Case #11
================================================================================

================================================================================
Test Case ID: 11
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const axios = require('axios');

class ApiService {
    constructor(baseURL) {
        this.baseURL = baseURL;
    }

    async fetchData(endpoint) {
        try {
            const response = await axios.get(`${this.baseURL}${endpoint}`);
            return response.data;
        } catch (error) {
            throw new Error('Error fetching data from API');
        }
    }
}

// Usage example
const apiService = new ApiService('https://api.example.com');

async function getUserData(userId) {
    try {
        const userData = await apiService.fetchData(`/users/${userId}`);


GOLDEN COMPLETION:
----------------------------------------
        if (!userData.id || userData.id !== userId) {
            throw new Error('User ID mismatch');
        }


SUFFIX CODE:
----------------------------------------
        if (!userData || !userData.name) {
            throw new Error('User data is invalid');
        }
        return userData;
    } catch (error) {
        console.error('Failed to get user data:', error.message);
        throw error;
    }
}

// Example usage of getUserData function
(async () => {
    try {
        const user = await getUserData(123);
        console.log('User data:', user);
    } catch (error) {
        console.error('Error:', error.message);
    }
})();


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand the business logic of fetching user data from an API and validating the user ID. It requires comprehension of asynchronous functions, error handling, and the specific business rule of ensuring the fetched user ID matches the requested user ID. The golden completion correctly implements this validation, while the suffix continues with further checks and error handling.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
(async () => {
    const mockApiService = {
        fetchData: async (endpoint) => {
            if (endpoint === '/users/123') {
                return { id: 123, name: 'John Doe' };
            }
            throw new Error('User not found');
        }
    };
    const apiService = mockApiService;

    try {
        const user = await getUserData(123);
        assert.strictEqual(user.id, 123, 'User ID should match the requested ID');
        assert.strictEqual(user.name, 'John Doe', 'User name should be John Doe');
        console.log('All assertions passed');
    } catch (error) {
        console.error('Assertions failed:', error.message);
    }
})();

================================================================================

================================================================================
Test Case #12
================================================================================

================================================================================
Test Case ID: 12
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Class to monitor file changes and log them
class FileMonitor {
    constructor(directory) {
        this.directory = directory;
        this.logFile = path.join(directory, 'file_changes.log');
    }

    async init() {
        // Ensure log file exists
        await fs.promises.writeFile(this.logFile, '', { flag: 'a' });
    }

    async logChange(filename) {
        const logEntry = `${new Date().toISOString()} - ${filename} was changed\n`;
        await fs.promises.appendFile(this.logFile, logEntry);
    }

    watch() {
        fs.watch(this.directory, (eventType, filename) => {
            if (eventType === 'change') {
                this.logChange(filename);
            }
        });
    }
}

(async () => {
    const monitor = new FileMonitor('./watched_directory');
    await monitor.init();
    monitor.watch();

    // Simulate a file change for testing purposes
    const testFilePath = path.join('./watched_directory', 'test_file.txt');
    await fs.promises.writeFile(testFilePath, 'Initial content');


GOLDEN COMPLETION:
----------------------------------------
    // Trigger a file change event
    await new Promise(resolve => setTimeout(resolve, 100)); // Allow some time for the watcher to initialize
    await fs.promises.writeFile(testFilePath, 'Updated content');


SUFFIX CODE:
----------------------------------------
    // Clean up
    await fs.promises.unlink(testFilePath);
    await fs.promises.unlink(monitor.logFile);
})();


JUSTIFICATION:
----------------------------------------
This scenario tests the LLM's ability to understand and continue a JavaScript class that monitors file changes and logs them. The domain context is system operations, specifically logging file changes. The technical pattern involves promises and async/await for asynchronous file operations. The completion must appropriately trigger a file change event and ensure that it is logged correctly. This tests the model's understanding of asynchronous code execution and event handling in a real-world monitoring scenario.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const logContent = fs.readFileSync(path.join('./watched_directory', 'file_changes.log'), 'utf-8');
assert(logContent.includes('test_file.txt was changed'), 'Log should contain the file change entry');

================================================================================

================================================================================
Test Case #13
================================================================================

================================================================================
Test Case ID: 13
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const { promisify } = require('util');
const readFileAsync = promisify(fs.readFile);
const writeFileAsync = promisify(fs.writeFile);

async function processLogFiles(inputFilePath, outputFilePath) {
    try {
        // Read the log file
        const data = await readFileAsync(inputFilePath, 'utf-8');

        // Process the log data (e.g., filtering errors)
        const lines = data.split('\n');
        const errorLines = lines.filter(line => line.includes('ERROR'));

        // Perform some analysis (e.g., counting errors)
        const errorCount = errorLines.length;
        const result = `Total Errors: ${errorCount}\n` + errorLines.join('\n');

        // Write the analysis result to the output file


GOLDEN COMPLETION:
----------------------------------------
        await writeFileAsync(outputFilePath, result, 'utf-8');

SUFFIX CODE:
----------------------------------------
        console.log('Log processing complete.');
    } catch (error) {
        console.error('Error processing log files:', error);
    }
}

// Example usage:
(async () => {
    await processLogFiles('input.log', 'output.log');
})();

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand and complete an async function for processing log files, which involves reading from a file, processing the content, and writing the results to another file. The domain context is system operations (logging). The completion must correctly place the write operation within the async function and ensure the correct handling of asynchronous file operations using Promises and async/await.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mock = require('mock-fs');

// Mock the file system
mock({
    'input.log': 'INFO: Initialization complete\nERROR: Failed to load module\nINFO: Process started\nERROR: Connection timeout\n',
    'output.log': ''
});

(async () => {
    await processLogFiles('input.log', 'output.log');
    const outputData = fs.readFileSync('output.log', 'utf-8');
    assert(outputData.includes('Total Errors: 2'), 'Error count should be 2');
    assert(outputData.includes('ERROR: Failed to load module'), 'Output should contain the first error');
    assert(outputData.includes('ERROR: Connection timeout'), 'Output should contain the second error');
    mock.restore();
})();
================================================================================

================================================================================
Test Case #14
================================================================================

================================================================================
Test Case ID: 14
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');
const fs = require('fs');

// Function to fetch and process image metadata
async function fetchImageMetadata(url) {
  try {
    const response = await fetch(url);
    if (!response.ok) {
      throw new Error('Network response was not ok');
    }
    const metadata = await response.json();
    return metadata;
  } catch (error) {
    console.error('Failed to fetch image metadata:', error);
    throw error;
  }
}

// Function to save metadata to a file
async function saveMetadataToFile(metadata, filePath) {
  return new Promise((resolve, reject) => {
    fs.writeFile(filePath, JSON.stringify(metadata, null, 2), (err) => {
      if (err) {
        reject(err);
      } else {
        resolve();
      }
    });
  });
}

// Main function to process image metadata
async function processImage(url, filePath) {
  try {
    const metadata = await fetchImageMetadata(url);


GOLDEN COMPLETION:
----------------------------------------
    await saveMetadataToFile(metadata, filePath);


SUFFIX CODE:
----------------------------------------
    console.log('Metadata processing complete');
  } catch (error) {
    console.error('Error processing image:', error);
  }
}

// Example usage
const imageUrl = 'https://example.com/image-metadata';
const metadataFilePath = './image-metadata.json';

processImage(imageUrl, metadataFilePath).then(() => {
  console.log('Image metadata fetched and saved successfully.');
}).catch((error) => {
  console.error('Failed to fetch and save image metadata:', error);
});


JUSTIFICATION:
----------------------------------------
This test case is a good example for evaluating an LLM's ability to understand the purpose of asynchronous operations in the context of media processing. The scenario involves fetching image metadata from a URL and saving it to a file, which is a realistic task in media processing workflows. The assertions verify that the metadata is correctly fetched and saved, ensuring semantic correctness and adherence to business logic.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const path = require('path');
const metadataFilePath = path.resolve('./image-metadata.json');

processImage('https://jsonplaceholder.typicode.com/photos/1', metadataFilePath).then(() => {
  const savedMetadata = JSON.parse(fs.readFileSync(metadataFilePath, 'utf8'));
  assert.strictEqual(savedMetadata.id, 1, 'Metadata ID should match');
  assert.strictEqual(savedMetadata.albumId, 1, 'Album ID should match');
  assert.strictEqual(savedMetadata.title, 'accusamus beatae ad facilis cum similique qui sunt', 'Title should match');
  assert.strictEqual(savedMetadata.url, 'https://via.placeholder.com/600/92c952', 'URL should match');
  assert.strictEqual(savedMetadata.thumbnailUrl, 'https://via.placeholder.com/150/92c952', 'Thumbnail URL should match');
  console.log('All assertions passed.');
}).catch((error) => {
  console.error('Assertions failed:', error);
});

================================================================================

================================================================================
Test Case #15
================================================================================

================================================================================
Test Case ID: 15
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read and validate a JSON file asynchronously
async function readAndValidateJSON(filePath) {
    if (!fs.existsSync(filePath)) {
        throw new Error('File does not exist');
    }
    const data = await fs.promises.readFile(filePath, 'utf-8');
    let jsonData;
    try {
        jsonData = JSON.parse(data);
    } catch (error) {
        throw new Error('Invalid JSON format');
    }
    if (!jsonData.name || !jsonData.age) {
        throw new Error('Invalid JSON structure');
    }
    return jsonData;
}

// Simulating a JSON file path
const filePath = path.join(__dirname, 'data.json');

// Function to run the validation
async function runValidation() {
    try {
        const result = await readAndValidateJSON(filePath);


GOLDEN COMPLETION:
----------------------------------------
        if (result.age < 0) {
            throw new Error('Age must be a positive number');
        }


SUFFIX CODE:
----------------------------------------
        console.log('Validation successful:', result);
    } catch (error) {
        console.error('Validation failed:', error.message);
    }
}

// Execute the validation function
runValidation();

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand async/await patterns in the context of data validation. The completion requires the LLM to recognize the logical flow of reading, parsing, and validating a JSON file's content, and to correctly add a business rule validation (age must be a positive number) that fits within the established pattern.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

// Mocking file read operation
const mockReadFile = async (filePath, encoding) => {
    assert.strictEqual(filePath, filePath);
    assert.strictEqual(encoding, 'utf-8');
    return '{"name": "John Doe", "age": -5}';
};

// Mocking fs.promises.readFile
fs.promises.readFile = mockReadFile;

// Run validation and check assertions
(async () => {
    try {
        await runValidation();
    } catch (error) {
        assert.strictEqual(error.message, 'Age must be a positive number');
    }
})();
================================================================================

================================================================================
Test Case #16
================================================================================

================================================================================
Test Case ID: 16
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read and parse a JSON file from disk
function readJSONFile(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf-8', (err, data) => {
            if (err) {
                return reject(err);
            }
            try {
                const jsonData = JSON.parse(data);
                resolve(jsonData);
            } catch (parseErr) {
                reject(parseErr);
            }
        });
    });
}

// Function to validate the structure of the parsed JSON data
function validateData(schema, data) {
    for (let key in schema) {
        if (schema.hasOwnProperty(key)) {
            if (typeof data[key] !== schema[key]) {
                throw new Error(`Invalid type for key ${key}: expected ${schema[key]}, got ${typeof data[key]}`);
            }
        }
    }
}

// Schema definition for the expected data structure
const schema = {
    name: 'string',
    age: 'number',
    email: 'string'
};

// Read and validate JSON file
const filePath = path.join(__dirname, 'data.json');
readJSONFile(filePath)
    .then(data => {
        // Validate the data against the schema

GOLDEN COMPLETION:
----------------------------------------
        validateData(schema, data);

SUFFIX CODE:
----------------------------------------
        console.log('Data is valid');
    })
    .catch(err => {
        console.error('Error:', err.message);
    });


JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to understand async-await patterns combined with data validation in a system operations context. It assesses whether the LLM can correctly place a function call within a promise chain, ensuring that the data read from a file is validated according to a specified schema. The completion demonstrates the understanding of async-await patterns and business logic related to data validation.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

// Mock fs.readFile to simulate reading a valid JSON file
fs.readFile = (filePath, encoding, callback) => {
    const mockData = JSON.stringify({ name: 'John Doe', age: 30, email: 'john.doe@example.com' });
    callback(null, mockData);
};

// Test the read and validate process
readJSONFile(filePath)
    .then(data => {
        assert.doesNotThrow(() => validateData(schema, data), 'Data should be valid');
    })
    .catch(err => {
        assert.fail(`Unexpected error: ${err.message}`);
    });

================================================================================

================================================================================
Test Case #17
================================================================================

================================================================================
Test Case ID: 17
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

class Authentication {
  constructor() {
    this.users = new Map();
  }

  // Hashes a password using SHA-256
  hashPassword(password) {
    return crypto.createHash('sha256').update(password).digest('hex');
  }

  // Registers a new user with a username and password
  register(username, password) {
    if (this.users.has(username)) {
      throw new Error('User already exists');
    }
    const hashedPassword = this.hashPassword(password);
    this.users.set(username, hashedPassword);
  }

  // Authenticates a user by username and password
  authenticate(username, password) {
    if (!this.users.has(username)) {
      throw new Error('User does not exist');
    }


GOLDEN COMPLETION:
----------------------------------------
    const hashedPassword = this.hashPassword(password);
    const storedHashedPassword = this.users.get(username);


SUFFIX CODE:
----------------------------------------
    if (storedHashedPassword !== hashedPassword) {
      throw new Error('Invalid password');
    }
    return true;
  }
}

// Test cases
const auth = new Authentication();

// Register a new user
auth.register('testUser', 'testPassword');

// Authenticate the registered user
console.assert(auth.authenticate('testUser', 'testPassword') === true, 'Authentication should succeed');

// Authenticate with wrong password
try {
  auth.authenticate('testUser', 'wrongPassword');
} catch (e) {
  console.assert(e.message === 'Invalid password', 'Should throw invalid password error');
}

// Cleanup (if any resources need to be cleaned)
// In this case, no external resources to clean up


JUSTIFICATION:
----------------------------------------
This test case validates an LLM's understanding of security domain logic, specifically in authentication using hashed passwords. It involves error handling for user registration and authentication, which is crucial for security systems. The completion requires understanding the business logic of comparing hashed passwords to authenticate users, ensuring the LLM comprehends the purpose behind the code. The assertions test proper functionality and error conditions, ensuring the system behaves as expected in real-world scenarios.

ASSERTIONS:
----------------------------------------
const auth = new Authentication();
auth.register('testUser', 'testPassword');
console.assert(auth.authenticate('testUser', 'testPassword') === true, 'Authentication should succeed');
try {
  auth.authenticate('testUser', 'wrongPassword');
} catch (e) {
  console.assert(e.message === 'Invalid password', 'Should throw invalid password error');
}
================================================================================

================================================================================
Test Case #18
================================================================================

================================================================================
Test Case ID: 18
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read and parse JSON data from a file
function readJsonFile(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf8', (err, data) => {
            if (err) {
                return reject(err);
            }
            try {
                const jsonData = JSON.parse(data);
                resolve(jsonData);
            } catch (parseErr) {
                reject(parseErr);
            }
        });
    });
}

// Function to write JSON data to a file
function writeJsonFile(filePath, data) {
    return new Promise((resolve, reject) => {
        const jsonData = JSON.stringify(data, null, 2);
        fs.writeFile(filePath, jsonData, 'utf8', (err) => {
            if (err) {
                return reject(err);
            }
            resolve();
        });
    });
}

// Function to merge two JSON files into one
async function mergeJsonFiles(file1, file2, outputFile) {
    try {
        const data1 = await readJsonFile(file1);
        const data2 = await readJsonFile(file2);
        const mergedData = {...data1, ...data2};


GOLDEN COMPLETION:
----------------------------------------
        await writeJsonFile(outputFile, mergedData);


SUFFIX CODE:
----------------------------------------
        console.log('Files merged successfully!');
    } catch (error) {
        console.error('Error merging files:', error);
    }
}

// Example usage
const file1 = path.join(__dirname, 'data1.json');
const file2 = path.join(__dirname, 'data2.json');
const outputFile = path.join(__dirname, 'output.json');

mergeJsonFiles(file1, file2, outputFile);


JUSTIFICATION:
----------------------------------------
This example tests an LLM's ability to understand the purpose of merging two JSON files and writing the result to an output file. It requires comprehension of async/await patterns and error handling in the context of file operations. The domain context is system operations, specifically file handling and merging data. The golden completion demonstrates the necessary step to write the merged data to an output file, maintaining consistency with the established async/await pattern.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mockFs = require('mock-fs');

mockFs({
    'data1.json': JSON.stringify({ a: 1, b: 2 }),
    'data2.json': JSON.stringify({ b: 3, c: 4 }),
    'output.json': ''
});

(async () => {
    await mergeJsonFiles('data1.json', 'data2.json', 'output.json');
    const outputData = JSON.parse(fs.readFileSync('output.json', 'utf8'));
    assert.deepStrictEqual(outputData, { a: 1, b: 3, c: 4 });

    console.log('All assertions passed.');
    mockFs.restore();
})();

================================================================================

================================================================================
Test Case #19
================================================================================

================================================================================
Test Case ID: 19
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');
const dataFilePath = path.join(__dirname, 'data.json');

// Function to read and parse JSON data from a file
function readData(callback) {
    fs.readFile(dataFilePath, 'utf8', (err, data) => {
        if (err) {
            callback(err, null);
        } else {
            try {
                const jsonData = JSON.parse(data);
                callback(null, jsonData);
            } catch (parseErr) {
                callback(parseErr, null);
            }
        }
    });
}

// Function to validate the data structure
function validateData(data) {
    if (!Array.isArray(data)) {
        throw new Error('Data should be an array');
    }
    for (const item of data) {
        if (typeof item.id !== 'number' || typeof item.value !== 'string') {
            throw new Error('Invalid data structure');
        }
    }
}

// Function to clean data by removing items with empty values
function cleanData(data) {
    return data.filter(item => item.value.trim() !== '');
}

// Function to normalize data values to lowercase
function normalizeData(data) {

GOLDEN COMPLETION:
----------------------------------------

    return data.map(item => ({ ...item, value: item.value.toLowerCase() }));


SUFFIX CODE:
----------------------------------------
}

// Main processing function
function processData(callback) {
    readData((err, data) => {
        if (err) {
            callback(err);
        } else {
            try {
                validateData(data);
                const cleanedData = cleanData(data);
                const normalizedData = cleanedData.map(item => ({ ...item, value: item.value.toLowerCase() }));
                callback(null, normalizedData);
            } catch (processErr) {
                callback(processErr);
            }
        }
    });
}

// Example usage
processData((err, processedData) => {
    if (err) {
        console.error('Error processing data:', err);
    } else {
        console.log('Processed data:', processedData);
    }
});


JUSTIFICATION:
----------------------------------------
This scenario tests the LLM's ability to understand and correctly continue JavaScript code that processes and normalizes a dataset. The prefix sets up a series of functions to read, validate, clean, and normalize data, establishing the pattern of functional programming and data validation. The golden completion requires generating a mapping function that normalizes the data to lowercase, demonstrating comprehension of the data transformation logic. This tests the model's understanding of data normalization within the context of data validation and cleaning.

ASSERTIONS:
----------------------------------------
const testData = [
    { id: 1, value: 'Test' },
    { id: 2, value: 'Data' },
    { id: 3, value: 'Sample' },
    { id: 4, value: '' }
];
const expectedData = [
    { id: 1, value: 'test' },
    { id: 2, value: 'data' },
    { id: 3, value: 'sample' }
];
const cleanedAndNormalizedData = cleanData(testData).map(item => ({ ...item, value: item.value.toLowerCase() }));
console.assert(JSON.stringify(cleanedAndNormalizedData) === JSON.stringify(expectedData), 'Data should be normalized to lowercase and empty values removed');
console.log('All assertions passed');
================================================================================

================================================================================
Test Case #20
================================================================================

================================================================================
Test Case ID: 20
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read a file and log its content
function readFileAndLog(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf8', (err, data) => {
            if (err) {
                reject(err);
            } else {
                console.log(data);
                resolve(data);
            }
        });
    });
}

// Function to process files in a directory
async function processFilesInDirectory(directoryPath) {
    try {
        const files = await fs.promises.readdir(directoryPath);
        const fileReadPromises = files.map(file => {
            const filePath = path.join(directoryPath, file);
            return readFileAndLog(filePath);
        });


GOLDEN COMPLETION:
----------------------------------------
        await Promise.all(fileReadPromises);

SUFFIX CODE:
----------------------------------------
        console.log('All files processed');
    } catch (error) {
        console.error('Error processing files:', error);
    }
}

// Example usage
(async () => {
    const testDirectoryPath = './testDirectory';
    await processFilesInDirectory(testDirectoryPath);
})();

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand and correctly implement asynchronous file processing using Promises and async/await. The task involves reading multiple files from a directory and logging their content, which requires comprehension of asynchronous patterns and proper error handling. The completion focuses on correctly waiting for all file read operations to complete using `Promise.all`. This demonstrates understanding of the business logic of ensuring all files are processed before proceeding.

ASSERTIONS:
----------------------------------------
const mockFs = require('mock-fs');
const testDirectoryPath = './testDirectory';

mockFs({
    [testDirectoryPath]: {
        'file1.txt': 'Content of file1',
        'file2.txt': 'Content of file2',
        'file3.txt': 'Content of file3'
    }
});

(async () => {
    const log = console.log;
    let logs = [];
    console.log = (message) => logs.push(message);

    await processFilesInDirectory(testDirectoryPath);

    console.log = log;
    mockFs.restore();

    console.assert(logs.includes('Content of file1'), 'file1 content should be logged');
    console.assert(logs.includes('Content of file2'), 'file2 content should be logged');
    console.assert(logs.includes('Content of file3'), 'file3 content should be logged');
    console.assert(logs.includes('All files processed'), 'All files processed message should be logged');
})();
================================================================================

================================================================================
Test Case #21
================================================================================

================================================================================
Test Case ID: 21
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

class DataEncryptor {
  constructor(secretKey) {
    this.secretKey = secretKey;
  }

  encrypt(data) {
    const cipher = crypto.createCipher('aes-256-cbc', this.secretKey);
    let encrypted = cipher.update(data, 'utf8', 'hex');
    encrypted += cipher.final('hex');
    return encrypted;
  }

  decrypt(encryptedData) {
    const decipher = crypto.createDecipher('aes-256-cbc', this.secretKey);
    let decrypted = decipher.update(encryptedData, 'hex', 'utf8');
    decrypted += decipher.final('utf8');
    return decrypted;
  }
}

// Usage example
const secretKey = 'mySuperSecretKey12345';
const encryptor = new DataEncryptor(secretKey);
const originalData = 'Sensitive information that needs encryption';
const encryptedData = encryptor.encrypt(originalData);


GOLDEN COMPLETION:
----------------------------------------
const decryptedData = encryptor.decrypt(encryptedData);


SUFFIX CODE:
----------------------------------------


// Assertions
const assert = require('assert');
assert.strictEqual(decryptedData, originalData, 'The decrypted data should match the original data');
assert.notStrictEqual(encryptedData, originalData, 'The encrypted data should not match the original data');

// Clean up
console.log('All assertions passed.');

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand the purpose of encryption and decryption in a security context, using the OOP pattern. The prefix establishes the class that handles encryption and decryption, and the suffix contains assertions to check the correctness of these operations. The golden completion involves the decryption process, which is critical for verifying that the encrypted data can be correctly reverted to its original form.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
assert.strictEqual(decryptedData, originalData, 'The decrypted data should match the original data');
assert.notStrictEqual(encryptedData, originalData, 'The encrypted data should not match the original data');
================================================================================

================================================================================
Test Case #22
================================================================================

================================================================================
Test Case ID: 22
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read and parse a JSON file
function readJsonFileSync(filepath) {
  const file = fs.readFileSync(filepath, 'utf8');
  return JSON.parse(file);
}

// Function to validate the schema of the JSON data
function validateSchema(data, schema) {
  for (const key in schema) {
    if (schema.hasOwnProperty(key)) {
      if (typeof data[key] !== schema[key]) {
        return false;
      }
    }
  }
  return true;
}

// Sample schema and JSON file path
const schema = { name: 'string', age: 'number', email: 'string' };
const jsonFilePath = path.join(__dirname, 'sample.json');

// Read and validate JSON data
try {
  const jsonData = readJsonFileSync(jsonFilePath);
  

GOLDEN COMPLETION:
----------------------------------------
const isValid = validateSchema(jsonData, schema);

SUFFIX CODE:
----------------------------------------

  if (isValid) {
    console.log('JSON data is valid according to the schema.');
  } else {
    console.log('JSON data does not match the schema.');
  }
} catch (error) {
  console.error('Error reading or validating JSON data:', error);
}


JUSTIFICATION:
----------------------------------------
This test case checks the LLM's ability to understand and complete a function that validates JSON data against a schema. The provided prefix sets up the reading and parsing of a JSON file, and the schema validation function is defined. The golden completion correctly uses the `validateSchema` function to validate the parsed JSON data, which is crucial for ensuring that the subsequent code correctly handles the validity of the data. The suffix demonstrates the continuation of the business logic based on the validation result, which is essential for verifying the LLM's comprehension of the overall code purpose.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mockFs = require('mock-fs');

// Mock the file system
mockFs({
  'sample.json': JSON.stringify({ name: 'John Doe', age: 30, email: 'john@example.com' })
});

// Read and validate the mock JSON data
try {
  const jsonData = readJsonFileSync(jsonFilePath);
  const isValid = validateSchema(jsonData, schema);
  assert.strictEqual(isValid, true, 'The JSON data should be valid according to the schema');
} finally {
  mockFs.restore();
}

================================================================================

================================================================================
Test Case #23
================================================================================

================================================================================
Test Case ID: 23
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const assert = require('assert');

// Function to simulate data validation for an API response
function validateApiResponse(response) {
  // Check for required fields
  const requiredFields = ['id', 'name', 'status'];
  for (const field of requiredFields) {
    if (!response.hasOwnProperty(field)) {
      throw new Error(`Missing required field: ${field}`);
    }
  }

  // Validate data types
  if (typeof response.id !== 'number') {
    throw new Error('Invalid type for field: id');
  }
  if (typeof response.name !== 'string') {
    throw new Error('Invalid type for field: name');
  }
  if (typeof response.status !== 'string') {
    throw new Error('Invalid type for field: status');
  }

  // Additional custom validation logic


GOLDEN COMPLETION:
----------------------------------------
  if (response.status !== 'active' && response.lastActiveDate) {
    throw new Error('lastActiveDate should not be present for non-active status');
  }

SUFFIX CODE:
----------------------------------------
  if (response.status === 'active' && !response.lastActiveDate) {
    throw new Error('Missing lastActiveDate for active status');
  }
}

// Example API response
const apiResponse = {
  id: 123,
  name: 'Sample User',
  status: 'active',
  lastActiveDate: '2023-10-05'
};

// Assertions to verify the validation function
assert.doesNotThrow(() => validateApiResponse(apiResponse));

const invalidResponse = { id: 123, name: 'Sample User', status: 'active' };
assert.throws(() => validateApiResponse(invalidResponse), /Missing lastActiveDate for active status/);

console.log('All assertions passed!');

JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's capability to understand and continue a function that performs data validation on an API response. The function checks for required fields, validates data types, and includes custom validation logic based on business rules. The golden completion adds a validation rule that ensures the 'lastActiveDate' field should not be present if the status is not 'active', maintaining consistency with the validation logic provided in the prefix and suffix. This scenario is realistic and tests comprehension of both the technical pattern of error handling and the domain context of data validation in APIs.

ASSERTIONS:
----------------------------------------
assert.doesNotThrow(() => validateApiResponse({ id: 123, name: 'Sample User', status: 'inactive' }));
assert.throws(() => validateApiResponse({ id: 123, name: 'Sample User', status: 'inactive', lastActiveDate: '2023-10-05' }), /lastActiveDate should not be present for non-active status/);
================================================================================

================================================================================
Test Case #24
================================================================================

================================================================================
Test Case ID: 24
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

class User {
    constructor(username, password) {
        this.username = username;
        this.passwordHash = this.hashPassword(password);
    }

    hashPassword(password) {
        return crypto.createHash('sha256').update(password).digest('hex');
    }
}

class AuthenticationService {
    constructor() {
        this.users = [];
    }

    register(username, password) {
        const user = new User(username, password);
        this.users.push(user);
        return user;
    }

    authenticate(username, password) {
        const user = this.users.find(user => user.username === username);
        if (!user) return false;
        const passwordHash = crypto.createHash('sha256').update(password).digest('hex');
        return user.passwordHash === passwordHash;
    }
}

const authService = new AuthenticationService();

// Register a new user
const newUser = authService.register('testUser', 'securePassword');


GOLDEN COMPLETION:
----------------------------------------
// Attempt to authenticate with correct password
const isAuthenticated = authService.authenticate('testUser', 'securePassword');
console.assert(isAuthenticated === true, 'User should be authenticated with correct password');

SUFFIX CODE:
----------------------------------------
// Attempt to authenticate with incorrect password
const isAuthenticatedWrong = authService.authenticate('testUser', 'wrongPassword');
console.assert(isAuthenticatedWrong === false, 'User should not be authenticated with incorrect password');

// Clean up
console.log('All tests passed.');

JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate the LLM's understanding of both technical patterns and domain-specific logic. The scenario involves an authentication service that uses password hashing for security, a common real-world application. The golden completion requires the LLM to correctly implement the authentication logic, verifying that a user can be authenticated with the correct password. The assertions ensure that the business rules (correct password allows authentication, incorrect password denies it) are adhered to. This tests the LLM's ability to comprehend and continue code based on its semantic meaning and business context.

ASSERTIONS:
----------------------------------------
console.assert(newUser.username === 'testUser', 'Username should be testUser');
console.assert(newUser.passwordHash === crypto.createHash('sha256').update('securePassword').digest('hex'), 'Password hash should match');

================================================================================

================================================================================
Test Case #25
================================================================================

================================================================================
Test Case ID: 25
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');

// Function to calculate the average of an array of numbers
function calculateAverage(numbers) {
    if (numbers.length === 0) throw new Error('Array is empty');
    let sum = numbers.reduce((acc, num) => acc + num, 0);
    return sum / numbers.length;
}

// Function to read and parse JSON data from a file
function readJsonFile(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf8', (err, data) => {
            if (err) {
                reject(err);
            } else {
                try {
                    const json = JSON.parse(data);
                    resolve(json);
                } catch (parseErr) {
                    reject(parseErr);
                }
            }
        });
    });
}

// Function to calculate the average rating from a JSON file containing an array of ratings
async function calculateAverageRating(filePath) {
    try {
        const data = await readJsonFile(filePath);
        if (!Array.isArray(data.ratings)) throw new Error('Invalid data format');


GOLDEN COMPLETION:
----------------------------------------
        return calculateAverage(data.ratings);

SUFFIX CODE:
----------------------------------------
    } catch (error) {
        console.error('Error calculating average rating:', error);
        throw error;
    }
}

// Test code
(async () => {
    const filePath = 'ratings.json';
    try {
        const averageRating = await calculateAverageRating(filePath);
        console.log('Average Rating:', averageRating);
        // Assertions
        console.assert(typeof averageRating === 'number', 'Average rating should be a number');
        console.assert(averageRating > 0, 'Average rating should be greater than 0');
    } catch (error) {
        console.error('Test failed:', error);
    }
})();


JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate the LLM's ability to understand and correctly implement a function that reads JSON data from a file, processes it, and calculates a meaningful statistic (average rating). The scenario involves handling asynchronous file operations with Promises/async-await and ensuring proper error handling for both file read errors and data parsing issues. It tests the comprehension of the business logic to read ratings data from a file and calculate the average rating, which is a common task in data processing and analytics.

ASSERTIONS:
----------------------------------------
const fs = require('fs');
const mockData = JSON.stringify({ ratings: [4, 5, 3, 4] });
const filePath = 'ratings.json';
fs.writeFileSync(filePath, mockData);

(async () => {
    try {
        const averageRating = await calculateAverageRating(filePath);
        console.assert(typeof averageRating === 'number', 'Average rating should be a number');
        console.assert(averageRating === 4, 'Average rating should be 4');
    } catch (error) {
        console.error('Test failed:', error);
    } finally {
        fs.unlinkSync(filePath);
    }
})();

================================================================================

================================================================================
Test Case #26
================================================================================

================================================================================
Test Case ID: 26
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');

// Function to read and parse a JSON file for user data validation
function readAndValidateUserData(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf8', (err, data) => {
            if (err) {
                return reject(new Error('Error reading file'));
            }
            try {
                const userData = JSON.parse(data);
                if (!userData.name || typeof userData.name !== 'string') {
                    throw new Error('Invalid user name');
                }
                if (!userData.age || typeof userData.age !== 'number') {
                    throw new Error('Invalid user age');
                }
                resolve(userData);
            } catch (parseErr) {
                reject(new Error('Error parsing JSON'));
            }
        });
    });
}

// Sample function to use the validated user data for further processing
async function processUserData(filePath) {
    try {
        const userData = await readAndValidateUserData(filePath);
        console.log('User data is valid:', userData);


GOLDEN COMPLETION:
----------------------------------------
        // Perform additional operations with validated user data
        userData.processed = true;


SUFFIX CODE:
----------------------------------------
        console.log('User data successfully processed');
    } catch (err) {
        console.error('Failed to process user data:', err.message);
    }
}

// Test the function with a sample file
processUserData('sampleUserData.json');


JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to continue code based on domain-specific logic (data validation) and the async-await pattern for handling Promises. The completion requires understanding the context of user data validation and adding a meaningful operation on the user data. The suffix provides a different continuation that ensures the LLM can distinguish between the completion and subsequent code.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const sinon = require('sinon');
const mockFs = require('mock-fs');

// Mock file system
mockFs({
    'sampleUserData.json': JSON.stringify({ name: 'John Doe', age: 30 })
});

// Spy on console.log
const consoleLogSpy = sinon.spy(console, 'log');

// Run the processUserData function
processUserData('sampleUserData.json').then(() => {
    // Assertions
    assert(consoleLogSpy.calledWith('User data is valid:', { name: 'John Doe', age: 30, processed: true }));
    assert(consoleLogSpy.calledWith('User data successfully processed'));

    // Restore original console.log
    console.log.restore();
    // Restore the file system
    mockFs.restore();
}).catch(err => {
    // Restore original console.log and file system in case of error
    console.log.restore();
    mockFs.restore();
    throw err;
});

================================================================================

================================================================================
Test Case #27
================================================================================

================================================================================
Test Case ID: 27
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read and validate a JSON file
function readAndValidateJson(filePath, schema) {
    // Read the file content
    const fileContent = fs.readFileSync(filePath, 'utf8');
    // Parse the JSON content
    const jsonData = JSON.parse(fileContent);
    // Validate the JSON data against the schema
    validateJsonSchema(jsonData, schema);
    return jsonData;
}

// Sample schema for validation
const sampleSchema = {
    type: 'object',
    properties: {
        name: { type: 'string' },
        age: { type: 'number' },
        email: { type: 'string' }
    },
    required: ['name', 'age']
};

// Mock function to validate JSON schema
function validateJsonSchema(data, schema) {
    // In a real-world scenario, this function would use a library like Ajv to validate the schema
    if (typeof data !== 'object' || Array.isArray(data)) {
        throw new Error('Invalid data type');
    }
    for (const key of schema.required) {
        if (!data.hasOwnProperty(key)) {
            throw new Error(`Missing required property: ${key}`);
        }
    }
}

// Path to the sample JSON file
const sampleFilePath = path.join(__dirname, 'sample.json');


GOLDEN COMPLETION:
----------------------------------------
fs.writeFileSync(sampleFilePath, JSON.stringify({ name: 'John Doe', age: 30, email: 'john.doe@example.com' }));

SUFFIX CODE:
----------------------------------------

try {
    // Attempt to read and validate the JSON file
    const data = readAndValidateJson(sampleFilePath, sampleSchema);
    // Assertions to verify the data structure
    console.assert(data.name === 'John Doe', 'Expected name to be John Doe');
    console.assert(data.age === 30, 'Expected age to be 30');
    console.assert(data.email === 'john.doe@example.com', 'Expected email to be john.doe@example.com');
} catch (error) {
    console.error('Error:', error.message);
} finally {
    // Cleanup or additional logic can be added here
    console.log('Validation complete.');
}

JUSTIFICATION:
----------------------------------------
This test case validates the ability of the LLM to understand the context of reading, validating, and asserting JSON data in a file. The prefix sets up a function to read and validate JSON data against a schema. The golden completion writes a valid JSON object to a file, ensuring the subsequent read and validation can be performed correctly. The suffix contains assertions to check the correctness of the data read from the file. This tests the LLM's understanding of file operations, JSON handling, and schema validation in a real-world data validation context.

ASSERTIONS:
----------------------------------------
const data = readAndValidateJson(sampleFilePath, sampleSchema);
console.assert(data.name === 'John Doe', 'Expected name to be John Doe');
console.assert(data.age === 30, 'Expected age to be 30');
console.assert(data.email === 'john.doe@example.com', 'Expected email to be john.doe@example.com');
================================================================================

================================================================================
Test Case #28
================================================================================

================================================================================
Test Case ID: 28
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

// Function to hash passwords
class PasswordHasher {
    constructor(salt) {
        this.salt = salt;
    }

    hashPassword(password) {
        return new Promise((resolve, reject) => {
            crypto.pbkdf2(password, this.salt, 1000, 64, 'sha512', (err, derivedKey) => {
                if (err) reject(err);
                resolve(derivedKey.toString('hex'));
            });
        });
    }
}

// Function to validate passwords
class PasswordValidator {
    constructor(hasher) {
        this.hasher = hasher;
    }

    async validate(password, hashedPassword) {
        const hashedInput = await this.hasher.hashPassword(password);
        return hashedInput === hashedPassword;
    }
}

// Example usage
const salt = 'random_salt';
const hasher = new PasswordHasher(salt);
const validator = new PasswordValidator(hasher);

async function testPasswordValidation() {
    const password = 'securepassword';
    const hashedPassword = await hasher.hashPassword(password);

GOLDEN COMPLETION:
----------------------------------------

    const isValid = await validator.validate(password, hashedPassword);
    console.log(isValid); // Should be true


SUFFIX CODE:
----------------------------------------

    const isValid = await validator.validate(password, hashedPassword + 'incorrect');
    console.log(isValid); // Should be false
}

testPasswordValidation();

JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to understand the business logic behind password hashing and validation, ensuring that it correctly implements the validation process by comparing a hashed password against its stored hashed value. The completion must show comprehension of validating the exact hashed password rather than an incorrect one, reflecting real-world security practices.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
(async () => {
    const password = 'securepassword';
    const salt = 'random_salt';
    const hasher = new PasswordHasher(salt);
    const validator = new PasswordValidator(hasher);
    const hashedPassword = await hasher.hashPassword(password);
    const isValid = await validator.validate(password, hashedPassword);
    assert.strictEqual(isValid, true, 'Password should be validated correctly');
    const isInvalid = await validator.validate(password, hashedPassword + 'incorrect');
    assert.strictEqual(isInvalid, false, 'Incorrect password should not be validated');
})();
================================================================================

================================================================================
Test Case #29
================================================================================

================================================================================
Test Case ID: 29
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

class User {
  constructor(username, password) {
    this.username = username;
    this.passwordHash = this.hashPassword(password);
    this.failedLoginAttempts = 0;
  }

  hashPassword(password) {
    return crypto.createHash('sha256').update(password).digest('hex');
  }

  authenticate(password) {
    if (this.passwordHash === this.hashPassword(password)) {
      this.failedLoginAttempts = 0;
      return true;
    } else {
      this.failedLoginAttempts += 1;
      return false;
    }
  }

  lockAccount() {
    this.accountLocked = true;
  }

  shouldLockAccount() {
    return this.failedLoginAttempts >= 3;
  }
}

const user = new User('testuser', 'password123');


GOLDEN COMPLETION:
----------------------------------------
if (user.failedLoginAttempts >= 3) {
  user.lockAccount();
}


SUFFIX CODE:
----------------------------------------
if (user.shouldLockAccount()) {
  user.lockAccount();
}

// Assertions
const assert = require('assert');
assert.strictEqual(user.authenticate('wrongpassword'), false);
assert.strictEqual(user.failedLoginAttempts, 1);
assert.strictEqual(user.accountLocked, undefined);

assert.strictEqual(user.authenticate('wrongpassword'), false);
assert.strictEqual(user.failedLoginAttempts, 2);
assert.strictEqual(user.accountLocked, undefined);

assert.strictEqual(user.authenticate('wrongpassword'), false);
assert.strictEqual(user.failedLoginAttempts, 3);
assert.strictEqual(user.accountLocked, true);

assert.strictEqual(user.authenticate('password123'), false);
assert.strictEqual(user.failedLoginAttempts, 3);
assert.strictEqual(user.accountLocked, true);

JUSTIFICATION:
----------------------------------------
This test case is designed to check the LLM's understanding of the security domain, specifically around user authentication and account locking mechanisms. The scenario involves detecting multiple failed login attempts and locking the account to prevent further access. The business logic ensures that after three failed attempts, the account should be locked, which is a common security measure. The assertions verify that the user's account is correctly locked after the defined number of failed attempts and remains locked even if the correct password is provided afterward.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
assert.strictEqual(user.authenticate('wrongpassword'), false);
assert.strictEqual(user.failedLoginAttempts, 1);
assert.strictEqual(user.accountLocked, undefined);

assert.strictEqual(user.authenticate('wrongpassword'), false);
assert.strictEqual(user.failedLoginAttempts, 2);
assert.strictEqual(user.accountLocked, undefined);

assert.strictEqual(user.authenticate('wrongpassword'), false);
assert.strictEqual(user.failedLoginAttempts, 3);
assert.strictEqual(user.accountLocked, true);

assert.strictEqual(user.authenticate('password123'), false);
assert.strictEqual(user.failedLoginAttempts, 3);
assert.strictEqual(user.accountLocked, true);
================================================================================

================================================================================
Test Case #30
================================================================================

================================================================================
Test Case ID: 30
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const axios = require('axios');

// Function to fetch user data from an API and process it
async function fetchAndProcessUserData(userId) {
  try {
    const response = await axios.get(`https://api.example.com/users/${userId}`);
    const userData = response.data;
    
    // Validate user data schema
    if (!userData.id || !userData.name || !userData.email) {
      throw new Error('Invalid user data');
    }
    
    // Process user data
    const processedData = {
      id: userData.id,
      name: userData.name.toUpperCase(), // Convert name to uppercase
      email: userData.email.toLowerCase(), // Convert email to lowercase
      createdAt: new Date(userData.createdAt).toISOString() // Convert date to ISO string
    };
    
    // Return processed data


GOLDEN COMPLETION:
----------------------------------------
    return processedData;


SUFFIX CODE:
----------------------------------------

  } catch (error) {
    console.error('Error fetching or processing user data:', error);
    throw error;
  }
}

// Example usage
(async () => {
  try {
    const userId = 123;
    const result = await fetchAndProcessUserData(userId);
    console.log('Processed User Data:', result);
    
    // Assertions to verify the correctness of the processed data
    console.assert(result.id === 123, 'User ID should be 123');
    console.assert(result.name === 'JOHN DOE', 'User name should be uppercase');
    console.assert(result.email === 'john.doe@example.com', 'User email should be lowercase');
    console.assert(new Date(result.createdAt).toISOString() === '2023-01-01T00:00:00.000Z', 'User creation date should be in ISO string format');
  } catch (error) {
    console.error('Test failed:', error);
  }
})();


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand and continue code based on its semantic meaning and business context. The scenario involves fetching user data from an API, validating the data schema, processing the data (e.g., converting name to uppercase, email to lowercase, and date to ISO string), and returning the processed data. The golden completion ensures the processed data is returned correctly, maintaining business logic consistency. Assertions verify the correctness of the processed data, ensuring the function behaves as expected. The test case demonstrates practical usage of async/await, error handling, and data validation in a real-world scenario.

ASSERTIONS:
----------------------------------------
const userId = 123;
(async () => {
  const result = await fetchAndProcessUserData(userId);
  console.assert(result.id === 123, 'User ID should be 123');
  console.assert(result.name === 'JOHN DOE', 'User name should be uppercase');
  console.assert(result.email === 'john.doe@example.com', 'User email should be lowercase');
  console.assert(new Date(result.createdAt).toISOString() === '2023-01-01T00:00:00.000Z', 'User creation date should be in ISO string format');
})();

================================================================================

================================================================================
Test Case #31
================================================================================

================================================================================
Test Case ID: 31
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');

class Logger {
    constructor(filename) {
        this.filename = filename;
    }

    log(message) {
        const timestamp = new Date().toISOString();
        const logMessage = `${timestamp} - ${message}\n`;
        fs.appendFileSync(this.filename, logMessage, 'utf8');
    }
}

class Monitor {
    constructor(logger) {
        this.logger = logger;
        this.metrics = {};
    }

    recordMetric(name, value) {
        if (!this.metrics[name]) {
            this.metrics[name] = [];
        }
        this.metrics[name].push(value);
        this.logger.log(`Metric recorded: ${name} = ${value}`);
    }
}

const logger = new Logger('system.log');
const monitor = new Monitor(logger);

// Simulate recording some metrics
monitor.recordMetric('cpu_usage', 75);
monitor.recordMetric('memory_usage', 65);


GOLDEN COMPLETION:
----------------------------------------
Monitor.prototype.getMetricsSummary = function() {
    const summary = {};
    for (const [key, values] of Object.entries(this.metrics)) {
        const total = values.reduce((acc, val) => acc + val, 0);
        summary[key] = total / values.length;
    }
    return summary;
};


SUFFIX CODE:
----------------------------------------
const metricsSummary = monitor.getMetricsSummary();
console.log(metricsSummary);

JUSTIFICATION:
----------------------------------------
This example tests the model's understanding of an OOP pattern in the context of system operations. The Logger class handles logging messages to a file, and the Monitor class records system metrics while using the Logger to log these events. The task requires implementing a method to summarize the recorded metrics, demonstrating comprehension of class methods and data aggregation.

ASSERTIONS:
----------------------------------------
const summary = monitor.getMetricsSummary();
const expectedSummary = {
    cpu_usage: 75,
    memory_usage: 65
};
console.assert(JSON.stringify(summary) === JSON.stringify(expectedSummary), 'Metrics summary should correctly average recorded metrics');
fs.unlinkSync('system.log');
================================================================================

================================================================================
Test Case #32
================================================================================

================================================================================
Test Case ID: 32
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const crypto = require('crypto');

class User {
    constructor(username, password) {
        this.username = username;
        this.password = password;
        this.salt = crypto.randomBytes(16).toString('hex');
        this.hash = this.encryptPassword(password);
    }

    encryptPassword(password) {
        return crypto.pbkdf2Sync(password, this.salt, 1000, 64, 'sha512').toString('hex');
    }

    validatePassword(password) {
        const hash = crypto.pbkdf2Sync(password, this.salt, 1000, 64, 'sha512').toString('hex');
        return this.hash === hash;
    }
}

const users = [];

function registerUser(username, password) {
    const user = new User(username, password);
    users.push(user);
    return user;
}

function loginUser(username, password) {
    const user = users.find(u => u.username === username);
    if (!user) {
        return false;
    }
    return user.validatePassword(password);
}

// Register a new user
const newUser = registerUser('alice', 'password123');


GOLDEN COMPLETION:
----------------------------------------
// Attempt to login with valid password
const loginResult1 = loginUser('alice', 'password123');
console.assert(loginResult1 === true, 'Login should succeed with correct password');


SUFFIX CODE:
----------------------------------------
// Attempt to login with invalid password
const loginResult2 = loginUser('alice', 'wrongpassword');
console.assert(loginResult2 === false, 'Login should fail with incorrect password');

// Cleanup
users.length = 0;

JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to understand a common security pattern involving password encryption, storage, and validation. The scenario revolves around user registration and login, which are crucial aspects in authentication systems. The pattern includes hashing passwords using a salt, storing the hash, and validating user credentials. The completion requires the model to correctly implement the login check and assert its correctness. This tests comprehension of secure password handling and validation logic, ensuring that the LLM understands the purpose and business logic behind user authentication.

ASSERTIONS:
----------------------------------------
const loginResult1 = loginUser('alice', 'password123');
console.assert(loginResult1 === true, 'Login should succeed with correct password');
const loginResult2 = loginUser('alice', 'wrongpassword');
console.assert(loginResult2 === false, 'Login should fail with incorrect password');

================================================================================

================================================================================
Test Case #33
================================================================================

================================================================================
Test Case ID: 33
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read a file and process its contents
async function processFile(filePath) {
    try {
        const data = await fs.promises.readFile(filePath, 'utf-8');
        const lines = data.split('\n');
        const cleanedLines = lines.map(line => line.trim()).filter(line => line.length > 0);
        
        return cleanedLines;
    } catch (error) {
        console.error('Error reading file:', error);
        throw error;
    }
}

// Usage of processFile in a specific context
async function analyzeLogFile(logFilePath) {
    try {
        const logLines = await processFile(logFilePath);
        const errorLines = logLines.filter(line => line.includes('ERROR'));
        

GOLDEN COMPLETION:
----------------------------------------
        // Extracting timestamps from error lines
        const errorTimestamps = errorLines.map(line => {
            const match = line.match(/\[(.*?)\]/);
            return match ? match[1] : 'No timestamp';
        });
        console.log('Error timestamps:', errorTimestamps);
        

SUFFIX CODE:
----------------------------------------
        console.log('Number of errors:', errorLines.length);
        return errorLines;
    } catch (error) {
        console.error('Error processing log file:', error);
        throw error;
    }
}

// Testing the analyzeLogFile function
(async () => {
    const testLogPath = path.join(__dirname, 'test.log');
    const errorLines = await analyzeLogFile(testLogPath);
    console.assert(errorLines.length === 2, 'Expected 2 error lines');
    console.assert(errorLines[0].includes('ERROR'), 'First error line should contain ERROR');
    console.assert(errorLines[1].includes('ERROR'), 'Second error line should contain ERROR');
})();

JUSTIFICATION:
----------------------------------------
This test case is a good example for evaluating an LLM's understanding of async-await patterns in the context of system operations, specifically log file analysis. The completion involves extracting timestamps from error lines, which is a common real-world task when processing logs. This requires the model to understand both the technical pattern of async-await and the business context of log analysis. The assertions verify that the correct error lines are processed and that the timestamps are correctly extracted.

ASSERTIONS:
----------------------------------------
console.assert(errorTimestamps.length === errorLines.length, 'Timestamps should be extracted for each error line');
console.assert(errorTimestamps.every(ts => ts !== 'No timestamp'), 'All error lines should have a timestamp');
================================================================================

================================================================================
Test Case #34
================================================================================

================================================================================
Test Case ID: 34
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');

// Function to read a JSON file and parse its contents
function readJSONFile(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf8', (err, data) => {
            if (err) {
                return reject(err);
            }
            try {
                const json = JSON.parse(data);
                resolve(json);
            } catch (parseErr) {
                reject(parseErr);
            }
        });
    });
}

// Function to validate the structure of a user object
function validateUser(user) {
    if (!user.id || typeof user.id !== 'number') {
        throw new Error('Invalid user id');
    }
    if (!user.name || typeof user.name !== 'string') {
        throw new Error('Invalid user name');
    }
    if (!user.email || typeof user.email !== 'string') {
        throw new Error('Invalid user email');
    }
}

// Main function to read and validate users from a JSON file
async function main() {
    const filePath = './users.json';
    try {
        const users = await readJSONFile(filePath);

GOLDEN COMPLETION:
----------------------------------------
        users.forEach(user => {
            validateUser(user);
        });

SUFFIX CODE:
----------------------------------------
        users.forEach(user => {
            console.log(`User: ${user.name}, Email: ${user.email}`);
        });
    } catch (err) {
        console.error('Error reading or validating users:', err);
    }
}

main();


JUSTIFICATION:
----------------------------------------
This test case verifies the understanding of promises, async/await, and data validation in a system operations context. The code reads a JSON file containing user data, validates each user's structure, and logs the user information. The golden completion involves a validation step that ensures each user object adheres to the expected schema before further processing, which is critical for ensuring data integrity. The suffix demonstrates the logging of user data, which is a different operation and does not duplicate the validation logic. This separation tests the model's ability to comprehend and complete the code based on the business logic of validating user data.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mockFs = require('mock-fs');

// Mock the file system
mockFs({
    './users.json': '[{"id":1,"name":"Alice","email":"alice@example.com"},{"id":2,"name":"Bob","email":"bob@example.com"}]'
});

async function testMain() {
    const users = await readJSONFile('./users.json');
    users.forEach(user => {
        validateUser(user);
    });
    assert.strictEqual(users[0].name, 'Alice');
    assert.strictEqual(users[1].email, 'bob@example.com');
}

testMain().then(() => {
    console.log('All assertions passed');
    mockFs.restore();
}).catch(err => {
    console.error('Test failed:', err);
    mockFs.restore();
});

================================================================================

================================================================================
Test Case #35
================================================================================

================================================================================
Test Case ID: 35
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// This function reads a file asynchronously and processes its content
async function readFileAndProcess(filePath) {
  try {
    // Read file content
    const data = await fs.promises.readFile(filePath, 'utf-8');
    // Process the data
    const processedData = processData(data);
    return processedData;
  } catch (error) {
    console.error('Error reading or processing file:', error);
    throw error;
  }
}

// Mock processData function to simulate data processing
function processData(data) {
  // Simulate data processing
  return data.split('\n').map(line => line.trim()).filter(line => line.length > 0);
}

// Sample usage of readFileAndProcess function
(async () => {
  const filePath = path.join(__dirname, 'sample.txt');
  try {
    const result = await readFileAndProcess(filePath);


GOLDEN COMPLETION:
----------------------------------------
    // Check if the file exists before processing
    if (!fs.existsSync(filePath)) {
      throw new Error('File does not exist');
    }


SUFFIX CODE:
----------------------------------------
    console.log('Processed Data:', result);
  } catch (error) {
    console.error('Failed to process file:', error);
  }
})();


JUSTIFICATION:
----------------------------------------
This example tests an LLM's understanding of the async-await pattern in the context of file operations. The domain context is tool automation, specifically reading and processing a file asynchronously. The completion involves checking the existence of the file before attempting to read it, which is a crucial step in robust file handling. This ensures that the LLM understands the necessity of verifying file existence to prevent runtime errors.

ASSERTIONS:
----------------------------------------
const mockFs = require('mock-fs');
mockFs({
  'sample.txt': 'line1\nline2\nline3\n',
  'empty.txt': ''
});

(async () => {
  const filePath = path.join(__dirname, 'sample.txt');
  const result = await readFileAndProcess(filePath);
  console.assert(Array.isArray(result), 'Result should be an array');
  console.assert(result.length === 3, 'Result should have 3 lines');
  console.assert(result[0] === 'line1', 'First line should be "line1"');
  console.assert(result[1] === 'line2', 'Second line should be "line2"');
  console.assert(result[2] === 'line3', 'Third line should be "line3"');
})();

(async () => {
  try {
    const filePath = path.join(__dirname, 'nonexistent.txt');
    await readFileAndProcess(filePath);
  } catch (error) {
    console.assert(error.message === 'File does not exist', 'Error message should be "File does not exist"');
  }
})();
mockFs.restore();
================================================================================

================================================================================
Test Case #36
================================================================================

================================================================================
Test Case ID: 36
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');

class AnalyticsService {
    constructor(apiEndpoint) {
        this.apiEndpoint = apiEndpoint;
    }

    async fetchReport(reportId) {
        try {
            const response = await fetch(`${this.apiEndpoint}/reports/${reportId}`);
            if (!response.ok) {
                throw new Error('Network response was not ok');
            }
            const reportData = await response.json();
            return reportData;
        } catch (error) {
            console.error('Fetch report failed:', error);
            throw error;
        }
    }
}

// Usage example:
const analyticsService = new AnalyticsService('https://api.example.com');

(async () => {
    try {
        const reportId = '12345';
        const report = await analyticsService.fetchReport(reportId);
        console.log('Report fetched successfully:', report);


GOLDEN COMPLETION:
----------------------------------------
        if (report.metrics && Array.isArray(report.metrics)) {
            report.metrics.forEach(metric => {
                console.log(`Metric: ${metric.name}, Value: ${metric.value}`);
            });
        } else {
            console.warn('No metrics found in the report');
        }


SUFFIX CODE:
----------------------------------------
        console.log('Report processing complete');
    } catch (error) {
        console.error('Error processing report:', error);
    }
})();


JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate an LLM's understanding of both async/await patterns and the domain context of analytics reporting. The prefix sets up an AnalyticsService class that fetches a report from an API, demonstrating real-world usage of network protocols and error handling. The golden completion involves processing the fetched report data, verifying its structure, and logging the metrics, which is a common task in analytics. Assertions will check both the correct retrieval and processing of the report data, ensuring semantic and functional correctness.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

(async () => {
    const mockFetch = async (url) => {
        assert.strictEqual(url, 'https://api.example.com/reports/12345');
        return {
            ok: true,
            json: async () => ({ metrics: [{ name: 'views', value: 1000 }, { name: 'clicks', value: 150 }] })
        };
    };

    const originalFetch = global.fetch;
    global.fetch = mockFetch;

    try {
        const analyticsService = new AnalyticsService('https://api.example.com');
        const report = await analyticsService.fetchReport('12345');
        assert.strictEqual(report.metrics.length, 2);
        assert.strictEqual(report.metrics[0].name, 'views');
        assert.strictEqual(report.metrics[0].value, 1000);
        assert.strictEqual(report.metrics[1].name, 'clicks');
        assert.strictEqual(report.metrics[1].value, 150);
    } finally {
        global.fetch = originalFetch;
    }
})();

================================================================================

================================================================================
Test Case #37
================================================================================

================================================================================
Test Case ID: 37
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');

// Function to fetch and process user data from an API
async function fetchData(url) {
    try {
        const response = await fetch(url);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        const data = await response.json();
        return data;
    } catch (error) {
        console.error('There was a problem with the fetch operation:', error);
        throw error;
    }
}

// Function to calculate the average age of users
async function calculateAverageAge(url) {
    try {
        const users = await fetchData(url);
        let totalAge = 0;
        let userCount = 0;
        // Process each user to accumulate age and count
        for (const user of users) {


GOLDEN COMPLETION:
----------------------------------------
            totalAge += user.age;
            userCount += 1;


SUFFIX CODE:
----------------------------------------
        }
        // Calculate average age
        const averageAge = totalAge / userCount;
        return averageAge;
    } catch (error) {
        console.error('Error calculating average age:', error);
        throw error;
    }
}

// URL of the API endpoint
const apiUrl = 'https://api.example.com/users';

// Example of calling the function and logging the result
calculateAverageAge(apiUrl)
    .then(averageAge => console.log(`Average Age: ${averageAge}`))
    .catch(error => console.error('Failed to calculate average age:', error));


JUSTIFICATION:
----------------------------------------
This test case is a good example of understanding async-await and error handling within the context of fetching data from an API and processing it. The completion involves correctly iterating over the user data to accumulate the total age and count, which is critical for calculating the average age. This demonstrates comprehension of both the technical pattern and the business logic involved in processing user data from an API.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

(async () => {
    const mockFetch = async (url) => {
        if (url === 'https://api.example.com/users') {
            return {
                ok: true,
                json: async () => ([
                    { age: 25 },
                    { age: 30 },
                    { age: 35 }
                ])
            };
        }
        throw new Error('Invalid URL');
    };

    // Mock fetch function
    global.fetch = mockFetch;

    const averageAge = await calculateAverageAge('https://api.example.com/users');
    assert.strictEqual(averageAge, 30, 'Average age should be 30');

    console.log('All assertions passed.');
})();

================================================================================

================================================================================
Test Case #38
================================================================================

================================================================================
Test Case ID: 38
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to read a file and process its contents
async function readFileAndProcess(filePath) {
    try {
        // Read file contents
        const data = await fs.promises.readFile(filePath, 'utf8');
        // Process data
        const processedData = data.split('\n').map(line => line.trim()).filter(line => line);
        return processedData;
    } catch (error) {
        console.error('Error reading file:', error);
        throw error;
    }
}

// Function to write processed data to a new file
async function writeProcessedData(filePath, data) {
    try {
        await fs.promises.writeFile(filePath, data.join('\n'), 'utf8');
    } catch (error) {
        console.error('Error writing file:', error);
        throw error;
    }
}

async function processFiles(inputFilePath, outputFilePath) {
    try {
        // Step 1: Read and process input file
        const processedData = await readFileAndProcess(inputFilePath);
        // Step 2: Perform additional processing
        const furtherProcessedData = processedData.map(line => line.toUpperCase());


GOLDEN COMPLETION:
----------------------------------------
        // Step 3: Filter out empty lines
        const nonEmptyLines = furtherProcessedData.filter(line => line.length > 0);


SUFFIX CODE:
----------------------------------------
        // Write the further processed data to output file
        await writeProcessedData(outputFilePath, furtherProcessedData);
    } catch (error) {
        console.error('Error processing files:', error);
    }
}

// Example usage
const inputFilePath = path.join(__dirname, 'input.txt');
const outputFilePath = path.join(__dirname, 'output.txt');

processFiles(inputFilePath, outputFilePath).then(() => {
    console.log('Files processed successfully');
}).catch(error => {
    console.error('Failed to process files:', error);
});


JUSTIFICATION:
----------------------------------------
This scenario demonstrates a practical use of Promises and async/await in the context of file processing, which is a common task in tool automation. The golden completion focuses on filtering out empty lines, which is a logical step in processing text files. This tests the LLM's ability to understand the semantic flow of the file processing pipeline and the business rule of ensuring only meaningful data is written to the output file.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mockFs = require('mock-fs');

// Mock the file system
mockFs({
    'input.txt': 'line1\nline2\n\nline3\n',
    'output.txt': ''
});

(async () => {
    const inputFilePath = path.join(__dirname, 'input.txt');
    const outputFilePath = path.join(__dirname, 'output.txt');
    await processFiles(inputFilePath, outputFilePath);
    const outputData = await fs.promises.readFile(outputFilePath, 'utf8');
    const expectedOutput = 'LINE1\nLINE2\nLINE3';
    assert.strictEqual(outputData, expectedOutput, 'Output data should match expected data');

    // Cleanup the mock file system
    mockFs.restore();
})();

================================================================================

================================================================================
Test Case #39
================================================================================

================================================================================
Test Case ID: 39
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');

async function getUserData(userId) {
    try {
        let response = await fetch(`https://api.example.com/users/${userId}`);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        let data = await response.json();
        return data;
    } catch (error) {
        console.error('Fetching user data failed', error);
        throw error;
    }
}

async function getUserPosts(userId) {
    try {
        let response = await fetch(`https://api.example.com/users/${userId}/posts`);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        let data = await response.json();
        return data;
    } catch (error) {
        console.error('Fetching user posts failed', error);
        throw error;
    }
}

async function getUserProfile(userId) {
    try {
        let userData = await getUserData(userId);
        let userPosts = await getUserPosts(userId);


GOLDEN COMPLETION:
----------------------------------------
        // Combine user data and posts into a single object
        return { userData, userPosts };


SUFFIX CODE:
----------------------------------------
    } catch (error) {
        console.error('Fetching user profile failed', error);
        throw error;
    }
}

(async () => {
    const userId = 1;
    try {
        let profile = await getUserProfile(userId);
        console.log(profile);
    } catch (error) {
        console.error('Error in fetching profile:', error);
    }
})();


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand and continue a function combining async-await pattern with network API calls. The scenario involves fetching user data and posts from an API and combining them into a single profile object. This tests comprehension of both error handling in async functions and the business logic of combining data from multiple sources.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
(async () => {
    const userId = 1;
    let profile;
    try {
        profile = await getUserProfile(userId);
        assert(profile.userData, 'User data should be present in profile');
        assert(profile.userPosts, 'User posts should be present in profile');
    } catch (error) {
        assert.fail('Fetching profile should not throw an error');
    }
})();

================================================================================

================================================================================
Test Case #40
================================================================================

================================================================================
Test Case ID: 40
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');

async function fetchAnalyticsData(url) {
    try {
        const response = await fetch(url);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        const data = await response.json();
        return data;
    } catch (error) {
        console.error('Failed to fetch analytics data:', error);
        throw error;
    }
}

async function processAnalytics(url) {
    try {
        const data = await fetchAnalyticsData(url);
        const processedData = data.map(item => ({
            id: item.id,
            value: item.value * 2 // Example processing
        }));
        return processedData;
    } catch (error) {
        console.error('Error processing analytics data:', error);
        throw error;
    }
}

(async () => {
    const url = 'https://api.example.com/analytics';


GOLDEN COMPLETION:
----------------------------------------
    try {
        const processedData = await processAnalytics(url);
        console.log('Processed Data:', processedData);
    } catch (error) {


SUFFIX CODE:
----------------------------------------
    console.error('Error in main execution:', error);
}
})();


JUSTIFICATION:
----------------------------------------
This test case is a good example because it evaluates the model's understanding of asynchronous operations and error handling within the context of fetching and processing analytics data. The code demonstrates the use of async/await with proper try/catch blocks to handle potential errors. The golden completion requires the model to correctly place and handle the async operations and error management, ensuring the fetched data is processed correctly before logging the output. This tests the model's ability to maintain logical flow and error handling in a real-world scenario.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mockFetch = async (url) => {
    if (url === 'https://api.example.com/analytics') {
        return {
            ok: true,
            json: async () => [{ id: 1, value: 10 }, { id: 2, value: 20 }]
        };
    }
    return { ok: false };
};

(async () => {
    const originalFetch = fetch;
    global.fetch = mockFetch;
    try {
        const url = 'https://api.example.com/analytics';
        const processedData = await processAnalytics(url);
        assert.deepStrictEqual(processedData, [
            { id: 1, value: 20 },
            { id: 2, value: 40 }
        ], 'Processed data does not match expected output');
    } finally {
        global.fetch = originalFetch;
    }
})();
================================================================================

================================================================================
Test Case #41
================================================================================

================================================================================
Test Case ID: 41
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Asynchronous function to read the content of a file
async function readFileContent(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf8', (err, data) => {
            if (err) {
                reject(err);
            } else {
                resolve(data);
            }
        });
    });
}

// Function to process file content and extract metrics
async function processFile(filePath) {
    try {
        const content = await readFileContent(filePath);
        const lines = content.split('\n');
        const wordCount = lines.reduce((count, line) => count + line.split(' ').length, 0);
        const charCount = content.length;
        return { lines: lines.length, wordCount, charCount };
    } catch (error) {
        console.error('Error processing file:', error);
        throw error;
    }
}

// Function to generate a report based on file metrics
async function generateReport(filePath) {
    const metrics = await processFile(filePath);
    const report = `File Metrics:\nLines: ${metrics.lines}\nWords: ${metrics.wordCount}\nCharacters: ${metrics.charCount}`;
    return report;
}

// Main execution function
async function main() {
    const filePath = path.join(__dirname, 'example.txt');


GOLDEN COMPLETION:
----------------------------------------
    try {
        const report = await generateReport(filePath);
        console.log(report);
    } catch (error) {
        console.error('Failed to generate report:', error);
    }


SUFFIX CODE:
----------------------------------------

}

main().catch(error => console.error('Main execution error:', error));


JUSTIFICATION:
----------------------------------------
This example tests the LLM's understanding of async/await patterns within the context of analytics. The completion requires correctly handling the promise returned by the generateReport function, including proper error handling to maintain robustness in the main execution flow. The scenario demonstrates a clear business purpose of generating a report based on file metrics, which is a common requirement in analytics.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

async function test() {
    const filePath = path.join(__dirname, 'example.txt');
    fs.writeFileSync(filePath, 'Hello world\nThis is a test file');

    const report = await generateReport(filePath);
    assert(report.includes('Lines: 2'));
    assert(report.includes('Words: 7'));
    assert(report.includes('Characters: 29'));

    fs.unlinkSync(filePath); // Cleanup
}

test().then(() => console.log('All assertions passed')).catch(error => console.error('Test failed:', error));

================================================================================

================================================================================
Test Case #42
================================================================================

================================================================================
Test Case ID: 42
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const axios = require('axios');

// Function to fetch user data from an API and return a processed result
async function fetchUserData(userId) {
    try {
        const response = await axios.get(`https://api.example.com/users/${userId}`);
        if (response.status === 200) {
            const userData = response.data;
            // Process user data
            return processUserData(userData);
        } else {
            throw new Error('Failed to fetch user data');
        }
    } catch (error) {
        console.error('Error fetching user data:', error);
        throw error;
    }
}

// Helper function to process user data
function processUserData(data) {
    return {
        id: data.id,
        name: data.name,
        email: data.email,
        registered: new Date(data.registered)
    };
}

// Function to fetch and log user data
async function fetchAndLogUserData(userId) {
    try {
        const userData = await fetchUserData(userId);
        console.log('User Data:', userData);


GOLDEN COMPLETION:
----------------------------------------
        return userData;


SUFFIX CODE:
----------------------------------------
    } catch (error) {
        console.error('Error:', error);
    }
}

// Example usage
(async () => {
    await fetchAndLogUserData(1);
})();


JUSTIFICATION:
----------------------------------------
This test case is designed to check the model's understanding of async/await patterns and error handling in the context of network protocols (API calls). The completion involves returning processed user data after fetching it from an API, which is a common real-world scenario. The assertions ensure that the function behaves correctly, logs the appropriate data, and handles errors properly.

ASSERTIONS:
----------------------------------------
const mockAxiosGet = jest.spyOn(axios, 'get').mockResolvedValue({ status: 200, data: { id: 1, name: 'John Doe', email: 'john@example.com', registered: '2023-01-01T00:00:00Z' } });
(async () => {
    const userData = await fetchUserData(1);
    console.assert(userData.id === 1, 'User ID should be 1');
    console.assert(userData.name === 'John Doe', 'User name should be John Doe');
    console.assert(userData.email === 'john@example.com', 'User email should be john@example.com');
    console.assert(userData.registered instanceof Date, 'Registered should be a Date object');
    mockAxiosGet.mockRestore();
})();

================================================================================

================================================================================
Test Case #43
================================================================================

================================================================================
Test Case ID: 43
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const util = require('util');
const readFile = util.promisify(fs.readFile);
const writeFile = util.promisify(fs.writeFile);

async function readAndProcessFile(filePath) {
    try {
        const data = await readFile(filePath, 'utf8');
        const json = JSON.parse(data);
        // Perform some analytics on the JSON data
        const analyticsResult = json.map(record => ({
            id: record.id,
            value: record.value * 2 // Example transformation
        }));


GOLDEN COMPLETION:
----------------------------------------
        await writeFile(filePath.replace('.json', '-processed.json'), JSON.stringify(analyticsResult));


SUFFIX CODE:
----------------------------------------
        return analyticsResult;
    } catch (error) {
        console.error('Error processing file:', error);
        throw error;
    }
}

(async () => {
    const testFilePath = './test-data.json';
    const testData = JSON.stringify([
        { id: 1, value: 10 },
        { id: 2, value: 20 }
    ]);

    await writeFile(testFilePath, testData);

    const result = await readAndProcessFile(testFilePath);

    console.log('Analytics Result:', result);
    // Cleanup
    fs.unlinkSync(testFilePath);
})();

JUSTIFICATION:
----------------------------------------
This test case is a good scenario because it evaluates the LLM's understanding of async/await patterns in the context of an analytics operation. The example demonstrates reading, processing, and writing files, which is common in data processing tasks. The completion requires the LLM to correctly write the processed data back to a new file, ensuring it understands both the semantic pattern of async/await and the business context of data transformation and storage. The assertions check the correctness of the transformation and the existence of the output file.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const processedFilePath = './test-data-processed.json';
assert(fs.existsSync(processedFilePath), 'Processed file should exist');
const processedData = JSON.parse(fs.readFileSync(processedFilePath, 'utf8'));
assert.deepStrictEqual(processedData, [
    { id: 1, value: 20 },
    { id: 2, value: 40 }
], 'Processed data should be correctly transformed');
// Cleanup
fs.unlinkSync(processedFilePath);
================================================================================

================================================================================
Test Case #44
================================================================================

================================================================================
Test Case ID: 44
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs').promises;

async function readFileContents(filepath) {
    try {
        const data = await fs.readFile(filepath, 'utf-8');
        return data;
    } catch (error) {
        throw new Error(`Failed to read file: ${error.message}`);
    }
}

async function writeFileContents(filepath, content) {
    try {
        await fs.writeFile(filepath, content, 'utf-8');
    } catch (error) {
        throw new Error(`Failed to write file: ${error.message}`);
    }
}

async function processFile(filepath) {
    try {
        const contents = await readFileContents(filepath);
        const updatedContents = contents.toUpperCase();


GOLDEN COMPLETION:
----------------------------------------
        await writeFileContents(filepath, updatedContents);


SUFFIX CODE:
----------------------------------------
        console.log('File processed successfully');
    } catch (error) {
        console.error(error.message);
    }
}

// Test case
(async () => {
    const testFile = 'test.txt';
    await writeFileContents(testFile, 'Hello World');
    await processFile(testFile);
    const result = await readFileContents(testFile);
    console.log('Processed content:', result);
})();

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand asynchronous file operations using Promises/async-await within the context of tool automation. The code demonstrates how to read, process, and write back to a file, ensuring that the business logic of processing file contents is correctly maintained. The completion involves writing the processed contents back to the file, which is critical for ensuring the file's updated state is saved. Assertions verify the correctness of the file's contents after processing.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

(async () => {
    const testFile = 'test.txt';
    await writeFileContents(testFile, 'Hello World');
    await processFile(testFile);
    const result = await readFileContents(testFile);
    assert.strictEqual(result, 'HELLO WORLD', 'File contents should be converted to uppercase');
    console.log('All assertions passed');
})();
================================================================================

================================================================================
Test Case #45
================================================================================

================================================================================
Test Case ID: 45
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');

// Function to fetch data from an API and process it
async function fetchDataAndProcess(url) {
    try {
        const response = await fetch(url);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        const data = await response.json();
        // Process data: Calculate the average value of a specific field
        const values = data.map(item => item.value);


GOLDEN COMPLETION:
----------------------------------------
        if (values.length === 0) {
            throw new Error('No values to process');
        }


SUFFIX CODE:
----------------------------------------
        const average = values.reduce((acc, val) => acc + val, 0) / values.length;
        return average;
    } catch (error) {
        console.error('Fetching or processing data failed:', error);
        throw error;
    }
}

// Example usage
(async () => {
    const testUrl = 'https://api.example.com/data';
    try {
        const averageValue = await fetchDataAndProcess(testUrl);
        console.log('Average Value:', averageValue);
        // Assert that the average value is correctly calculated
        console.assert(!isNaN(averageValue), 'Average value should be a number');
        console.assert(averageValue > 0, 'Average value should be greater than zero');
    } catch (error) {
        console.error('Test failed:', error);
    }
})();


JUSTIFICATION:
----------------------------------------
This test case checks the LLM's ability to comprehend and continue code based on its business logic and domain context. It involves fetching data from an API, processing the data to calculate an average value, and handling potential errors. The golden completion adds a crucial error handling step to ensure there are values to process before calculating the average, which is consistent with the given business logic. This tests the LLM's understanding of asynchronous operations, error handling, and data processing, making it a robust scenario for evaluating code purpose comprehension.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

(async () => {
    const testUrl = 'https://api.example.com/data';
    const mockData = [{ value: 10 }, { value: 20 }, { value: 30 }];
    global.fetch = async (url) => ({ ok: true, json: async () => mockData });
    try {
        const averageValue = await fetchDataAndProcess(testUrl);
        assert(!isNaN(averageValue), 'Average value should be a number');
        assert(averageValue > 0, 'Average value should be greater than zero');
        assert.strictEqual(averageValue, 20, 'Average value should be 20');
    } catch (error) {
        assert.fail('Test failed with error: ' + error.message);
    }
})();

================================================================================

================================================================================
Test Case #46
================================================================================

================================================================================
Test Case ID: 46
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');

// Function to fetch analytics data from an API
async function fetchAnalyticsData(url) {
  try {
    const response = await fetch(url);
    if (!response.ok) {
      throw new Error('Network response was not ok ' + response.statusText);
    }
    const data = await response.json();
    return data;
  } catch (error) {
    console.error('There has been a problem with your fetch operation:', error);
    throw error;
  }
}

// Example usage of fetchAnalyticsData
async function displayAnalytics() {
  const apiUrl = 'https://api.example.com/analytics';
  let analyticsData;


GOLDEN COMPLETION:
----------------------------------------
  try {
    analyticsData = await fetchAnalyticsData(apiUrl);
  } catch (error) {
    console.error('Error fetching analytics data:', error);
    return;
  }


SUFFIX CODE:
----------------------------------------

}

// Execute the function to display analytics
(async () => {
  try {
    await displayAnalytics();
    console.log('Analytics displayed successfully.');
  } catch (error) {
    console.error('Failed to display analytics:', error);
  }
})();


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to comprehend and continue JavaScript code involving async/await pattern within the context of fetching and displaying analytics data from an API. The example demonstrates proper error handling and business logic for network requests, which are crucial for real-world applications. The completion must correctly handle asynchronous operations and error scenarios to ensure the analytics data is fetched and displayed appropriately.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mockFetch = require('fetch-mock');

mockFetch.get('https://api.example.com/analytics', { visits: 100, sales: 50 });

(async () => {
  let consoleOutput = [];
  const mockedLog = (output) => consoleOutput.push(output);
  console.log = mockedLog;
  console.error = mockedLog;

  try {
    await displayAnalytics();
    assert(consoleOutput.includes('Analytics Data: { visits: 100, sales: 50 }'));
    assert(consoleOutput.includes('Analytics displayed successfully.'));
  } catch (error) {
    assert.fail('The function should not throw an error');
  } finally {
    mockFetch.restore();
  }
})();

================================================================================

================================================================================
Test Case #47
================================================================================

================================================================================
Test Case ID: 47
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const axios = require('axios');

// Function to fetch user data and compute average age
async function fetchUserDataAndComputeAverageAge(apiUrl) {
    try {
        const response = await axios.get(apiUrl);
        const users = response.data;

        if (!Array.isArray(users)) {
            throw new Error('Invalid data format');
        }

        let totalAge = 0;
        for (const user of users) {
            if (typeof user.age !== 'number') {
                throw new Error('Invalid user age');
            }
            totalAge += user.age;
        }
        const averageAge = totalAge / users.length;


GOLDEN COMPLETION:
----------------------------------------
        if (users.length === 0) {
            throw new Error('No users found');
        }


SUFFIX CODE:
----------------------------------------
        return averageAge;
    } catch (error) {
        console.error('Error fetching user data:', error.message);
        throw error;
    }
}

// Example usage
(async () => {
    const apiUrl = 'https://api.example.com/users';
    try {
        const averageAge = await fetchUserDataAndComputeAverageAge(apiUrl);
        console.log('Average age of users:', averageAge);
    } catch (error) {
        console.error('Failed to compute average age:', error.message);
    }
})();


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to understand the semantic meaning and business context of handling API responses and computing an average value. It demonstrates the async-await pattern in the context of fetching and processing user data from an API. The golden completion ensures that an appropriate error is thrown when no users are found, maintaining business logic consistency. Assertions verify that the function handles valid data, empty data, and invalid data formats correctly.

ASSERTIONS:
----------------------------------------
const mockAxios = require('axios');
const assert = require('assert');

mockAxios.get = async (url) => {
    if (url === 'https://api.example.com/users/valid') {
        return { data: [{ age: 30 }, { age: 40 }, { age: 50 }] };
    } else if (url === 'https://api.example.com/users/empty') {
        return { data: [] };
    } else if (url === 'https://api.example.com/users/invalid') {
        return { data: [{ age: 'thirty' }, { age: 40 }] };
    }
    throw new Error('Unknown URL');
};

(async () => {
    try {
        const validAverageAge = await fetchUserDataAndComputeAverageAge('https://api.example.com/users/valid');
        assert.strictEqual(validAverageAge, 40, 'Average age should be 40');
    } catch (e) {
        assert.fail('Valid data should not throw an error');
    }

    try {
        await fetchUserDataAndComputeAverageAge('https://api.example.com/users/empty');
        assert.fail('Empty data should throw an error');
    } catch (e) {
        assert.strictEqual(e.message, 'No users found', 'Error message should be "No users found"');
    }

    try {
        await fetchUserDataAndComputeAverageAge('https://api.example.com/users/invalid');
        assert.fail('Invalid data format should throw an error');
    } catch (e) {
        assert.strictEqual(e.message, 'Invalid user age', 'Error message should be "Invalid user age"');
    }
})();

================================================================================

================================================================================
Test Case #48
================================================================================

================================================================================
Test Case ID: 48
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

// Function to log deployment progress
function logDeploymentProgress(stage, message) {
    const logMessage = `${new Date().toISOString()} [${stage}] ${message}`;
    console.log(logMessage);
    fs.appendFileSync(path.join(__dirname, 'deployment.log'), logMessage + '\n');
}

// Function to deploy application
async function deployApplication(config) {
    try {
        logDeploymentProgress('START', 'Deployment started.');
        // Simulate configuration validation
        if (!config || !config.appName || !config.version) {
            throw new Error('Invalid configuration');
        }
        logDeploymentProgress('CONFIG', 'Configuration validated.');

        // Simulate build process
        await simulateBuildProcess(config.appName);
        logDeploymentProgress('BUILD', 'Build completed.');

        // Simulate deployment process
        await simulateDeploymentProcess(config);
        logDeploymentProgress('DEPLOY', 'Deployment completed.');
        
        // Simulate post-deployment checks


GOLDEN COMPLETION:
----------------------------------------
        await simulatePostDeploymentChecks(config);


SUFFIX CODE:
----------------------------------------
        logDeploymentProgress('CHECK', 'Post-deployment checks completed.');
        logDeploymentProgress('FINISH', 'Deployment finished successfully.');
    } catch (error) {
        logDeploymentProgress('ERROR', `Deployment failed: ${error.message}`);
        throw error;
    } finally {
        // Cleanup resources, if any
    }
}

// Mocked functions for simulation
async function simulateBuildProcess(appName) {
    return new Promise((resolve) => setTimeout(resolve, 1000));
}

async function simulateDeploymentProcess(config) {
    return new Promise((resolve) => setTimeout(resolve, 1000));
}

// Test the deployment function
(async () => {
    const testConfig = { appName: 'TestApp', version: '1.0.0' };
    await deployApplication(testConfig);
})();

JUSTIFICATION:
----------------------------------------
This example tests the LLM's understanding of async/await patterns within the context of a tool automation scenario for application deployment. It includes error handling, logging, and simulates various deployment stages. The completion is critical as it adds a post-deployment check, maintaining the business logic of ensuring deployment integrity. Assertions verify the correct sequence and error handling of deployment stages.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const logFilePath = path.join(__dirname, 'deployment.log');
const logContent = fs.readFileSync(logFilePath, 'utf-8');

assert(logContent.includes('[START] Deployment started.'), 'Start log message missing');
assert(logContent.includes('[CONFIG] Configuration validated.'), 'Configuration log message missing');
assert(logContent.includes('[BUILD] Build completed.'), 'Build log message missing');
assert(logContent.includes('[DEPLOY] Deployment completed.'), 'Deploy log message missing');
assert(logContent.includes('[CHECK] Post-deployment checks completed.'), 'Check log message missing');
assert(logContent.includes('[FINISH] Deployment finished successfully.'), 'Finish log message missing');

fs.unlinkSync(logFilePath); // Cleanup log file after assertions
================================================================================

================================================================================
Test Case #49
================================================================================

================================================================================
Test Case ID: 49
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fetch = require('node-fetch');

async function fetchUserData(userId) {
    const url = `https://api.example.com/users/${userId}`;
    try {
        const response = await fetch(url);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        const data = await response.json();
        return data;
    } catch (error) {
        console.error('Failed to fetch user data:', error);
    }
}

async function fetchUserOrders(userId) {
    const url = `https://api.example.com/users/${userId}/orders`;
    try {
        const response = await fetch(url);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        const data = await response.json();
        return data;
    } catch (error) {
        console.error('Failed to fetch user orders:', error);
    }
}

async function getUserDetails(userId) {
    try {
        const userDataPromise = fetchUserData(userId);
        const userOrdersPromise = fetchUserOrders(userId);


GOLDEN COMPLETION:
----------------------------------------
        const [userData, userOrders] = await Promise.all([userDataPromise, userOrdersPromise]);
        return { userData, userOrders };


SUFFIX CODE:
----------------------------------------
        return { userData: null, userOrders: null };
    } catch (error) {
        console.error('Failed to get user details:', error);
        throw error;
    }
}

(async () => {
    const userId = 1;
    const userDetails = await getUserDetails(userId);
    console.log(userDetails);
})();


JUSTIFICATION:
----------------------------------------
This scenario demonstrates understanding of async/await and promises in the context of making API requests to fetch user data and orders concurrently. The test case checks whether the LLM can correctly complete the function to wait for multiple asynchronous operations to complete using Promise.all and return the combined results. This is a common pattern in network protocols when dealing with multiple API calls, making it a practical and relevant test for code comprehension.

ASSERTIONS:
----------------------------------------
const assert = require('assert');

(async () => {
    const userId = 1;
    const userDetails = await getUserDetails(userId);
    assert(userDetails.userData !== null, 'User data should not be null');
    assert(userDetails.userOrders !== null, 'User orders should not be null');
    assert(Array.isArray(userDetails.userOrders), 'User orders should be an array');
})();

================================================================================

================================================================================
Test Case #50
================================================================================

================================================================================
Test Case ID: 50
Source: devbench-code-purpose-understanding
Language: javascript
================================================================================

PREFIX CODE:
----------------------------------------
const fs = require('fs');
const path = require('path');

function readConfig(filePath) {
    return new Promise((resolve, reject) => {
        fs.readFile(filePath, 'utf8', (err, data) => {
            if (err) {
                reject(err);
            } else {
                try {
                    const config = JSON.parse(data);
                    resolve(config);
                } catch (parseErr) {
                    reject(parseErr);
                }
            }
        });
    });
}

async function loadAppConfig() {
    const configPath = path.join(__dirname, 'config.json');
    try {
        const config = await readConfig(configPath);
        console.log('Config loaded:', config);


GOLDEN COMPLETION:
----------------------------------------
        if (config.enableFeatureX) {
            console.log('Feature X is enabled');
        }


SUFFIX CODE:
----------------------------------------
    } catch (error) {
        console.error('Error loading config:', error);
    }
}

loadAppConfig();

JUSTIFICATION:
----------------------------------------
This test case is a good example because it evaluates the model's understanding of async/await patterns in the context of loading and processing a configuration file for an application. The completion involves checking a specific configuration setting and performing an action based on that setting, which is a common real-world scenario. The assertions ensure that the configuration is correctly processed and the appropriate actions are taken based on the configuration values.

ASSERTIONS:
----------------------------------------
const assert = require('assert');
const mockFs = require('mock-fs');

mockFs({
    'config.json': JSON.stringify({ enableFeatureX: true })
});

(async () => {
    const consoleLog = console.log;
    const consoleError = console.error;
    let logOutput = '';
    let errorOutput = '';

    console.log = (msg) => { logOutput += msg + '\n'; };
    console.error = (msg) => { errorOutput += msg + '\n'; };

    await loadAppConfig();

    assert(logOutput.includes('Config loaded: { enableFeatureX: true }'));
    assert(logOutput.includes('Feature X is enabled'));
    assert(!errorOutput.includes('Error loading config'));

    console.log = consoleLog;
    console.error = consoleError;
    mockFs.restore();
})();
================================================================================
