I'm encountering an issue where files created during an Appwrite Function execution persist across subsequent executions. Specifically, when a function writes a file to the filesystem, that file remains available in the next execution, leading to errors.
Expected Behavior:
Each function execution should operate in an isolated environment with a clean filesystem, ensuring no residual data from previous runs.
Observed Behavior:
Files written during one execution are accessible in subsequent executions, indicating that the function's runtime environment is not being reset between runs.
Additional Context:
I am using Appwrite version 1.6.0 in a self-hosted setup. The function in question writes a file to a directory during execution. Upon re-execution, the function detects the existing file and throws an error.
Steps to Reproduce: Deploy a function that writes a file to a specific directory. Execute the function once; it should create the file successfully. Execute the function again; it detects the existing file and throws an error.
Impact: This behavior affects the reliability of functions that depend on a clean execution environment, potentially leading to unexpected errors and data inconsistencies.
Here is the function
import fs from 'fs';
import path from 'path';
async function testParallel() {
const dirPath = path.join('./data/test-parallel');
const testFilePath = path.join(dirPath, '/test.txt');
if (!fs.existsSync(dirPath)) {
fs.mkdirSync(dirPath, { recursive: true });
}
if (fs.existsSync(testFilePath)) {
throw new Error('Test file already exists');
}
// write file
fs.writeFileSync(testFilePath, 'This is a test file', 'utf8');
console.log('Test file created at', testFilePath);
// read file
const data = fs.readFileSync(testFilePath, 'utf8');
console.log('Test file data:', data);
// make the script wait 90 seconds
await new Promise((resolve) => {
setTimeout(() => {
console.log('Waited 90 seconds');
resolve();
}, 90000);
});
}
export { testParallel };
Recommended threads
- Streamlit UI and local DB
I want to use Appwrite for automation, like run watchdog service every morning 3 am. Anyone got suggestions, already explored github and documentation no luck. ...
- 408 Timeout / Curl Error 7 in Executor w...
Hey everyone, I am losing my mind over a routing loop/timeout issue on a fresh self-hosted setup. I have a single Linux VPS (IP: 45.141.37.105) and one domain (...
- functions returning error 401 in local
I updated to 1.9.0, and the functions that used to work fine in 1.8.1 are now giving me a 401 error. I can't seem to find a solution. If anyone is running versi...