{
    "timestamp": "2026-01-02 16:31:54",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Process started - Update completionminattempts for all quizzes with quiz_settings_type = 29",
    "memory_usage": "28 MB",
    "peak_memory": "28 MB"
}
{
    "timestamp": "2026-01-02 16:31:54",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Found 45 quizzes to process",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:55",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=101, Moodle ID=259, Name=Loại 6. Exercise: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:55",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=109, Moodle ID=266, Name=Loại 6. Exercise: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:55",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=168, Moodle ID=290, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:55",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=169, Moodle ID=291, Name=Practice - Unit 1 - Lesson 3: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:56",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=170, Moodle ID=292, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:56",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=171, Moodle ID=293, Name=Practice - Unit 1 - Lesson 4: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:56",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=178, Moodle ID=299, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:57",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=179, Moodle ID=300, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:57",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=180, Moodle ID=301, Name=Loại 6. Exercise: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:57",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=181, Moodle ID=302, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:57",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=10\/45, Updated=10, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:57",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=429, Moodle ID=1893, Name=Test 12\/08: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:58",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=441, Moodle ID=1897, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:58",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=442, Moodle ID=1898, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:58",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=443, Moodle ID=1899, Name=Post class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:59",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=445, Moodle ID=1901, Name=Talk To Me: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:59",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=448, Moodle ID=1902, Name=TEST EMBEDDED: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:59",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=450, Moodle ID=1903, Name=Test Correction audio LCAT (22\/08): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:31:59",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=509, Moodle ID=1924, Name=OMO Test: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:00",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=569, Moodle ID=1985, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:00",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=570, Moodle ID=1986, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:00",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=20\/45, Updated=20, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:00",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=571, Moodle ID=1987, Name=Post class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:01",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=573, Moodle ID=1988, Name=Talk To Me: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:01",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=579, Moodle ID=1991, Name=Đề Description: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:01",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=583, Moodle ID=2004, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:02",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=609, Moodle ID=2029, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:02",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=610, Moodle ID=2030, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:02",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=700, Moodle ID=2074, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:03",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=701, Moodle ID=2075, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:03",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=710, Moodle ID=2082, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:03",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=711, Moodle ID=2083, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:03",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=30\/45, Updated=30, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:04",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=716, Moodle ID=2087, Name=Test: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:04",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=745, Moodle ID=2114, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:04",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=757, Moodle ID=2121, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:04",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=759, Moodle ID=2123, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:05",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=763, Moodle ID=2127, Name=Practice - Unit 1 - Lesson 4: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:05",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=772, Moodle ID=2132, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:05",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=774, Moodle ID=2133, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:06",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=775, Moodle ID=2134, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:06",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=777, Moodle ID=2135, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:06",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=783, Moodle ID=2139, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:06",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=40\/45, Updated=40, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:06",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=785, Moodle ID=2141, Name=Post class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:07",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=788, Moodle ID=2143, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:07",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=791, Moodle ID=2145, Name=Talk To Me: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:08",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=812, Moodle ID=2164, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:08",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=813, Moodle ID=2165, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:32:08",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Process completed - Total=45, Processed=45, Updated=45, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:37",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Process started - Update completionminattempts for all quizzes with quiz_settings_type = 29",
    "memory_usage": "28 MB",
    "peak_memory": "28 MB"
}
{
    "timestamp": "2026-01-02 16:33:37",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Found 45 quizzes to process",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:37",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=101, Moodle ID=259, Name=Loại 6. Exercise: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:37",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=109, Moodle ID=266, Name=Loại 6. Exercise: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:37",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=168, Moodle ID=290, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:38",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=169, Moodle ID=291, Name=Practice - Unit 1 - Lesson 3: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:38",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=170, Moodle ID=292, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:38",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=171, Moodle ID=293, Name=Practice - Unit 1 - Lesson 4: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:38",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=178, Moodle ID=299, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:39",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=179, Moodle ID=300, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:39",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=180, Moodle ID=301, Name=Loại 6. Exercise: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:39",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=181, Moodle ID=302, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:39",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=10\/45, Updated=10, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:40",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=429, Moodle ID=1893, Name=Test 12\/08: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:40",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=441, Moodle ID=1897, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:40",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=442, Moodle ID=1898, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:40",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=443, Moodle ID=1899, Name=Post class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:41",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=445, Moodle ID=1901, Name=Talk To Me: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:41",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=448, Moodle ID=1902, Name=TEST EMBEDDED: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:41",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=450, Moodle ID=1903, Name=Test Correction audio LCAT (22\/08): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:42",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=509, Moodle ID=1924, Name=OMO Test: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:42",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=569, Moodle ID=1985, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:42",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=570, Moodle ID=1986, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:42",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=20\/45, Updated=20, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:43",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=571, Moodle ID=1987, Name=Post class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:43",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=573, Moodle ID=1988, Name=Talk To Me: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:43",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=579, Moodle ID=1991, Name=Đề Description: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:43",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=583, Moodle ID=2004, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:44",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=609, Moodle ID=2029, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:44",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=610, Moodle ID=2030, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:44",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=700, Moodle ID=2074, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:45",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=701, Moodle ID=2075, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:45",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=710, Moodle ID=2082, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:45",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=711, Moodle ID=2083, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:45",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=30\/45, Updated=30, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:45",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=716, Moodle ID=2087, Name=Test: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:46",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=745, Moodle ID=2114, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:46",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=757, Moodle ID=2121, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:46",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=759, Moodle ID=2123, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:46",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=763, Moodle ID=2127, Name=Practice - Unit 1 - Lesson 4: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:47",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=772, Moodle ID=2132, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:47",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=774, Moodle ID=2133, Name=Practice - Unit 1 - Lesson 1: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:47",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=775, Moodle ID=2134, Name=Practice - Unit 1 - Lesson 2: Daily life: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:48",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=777, Moodle ID=2135, Name=Loại 6. Exercise (có speaking): Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:48",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=783, Moodle ID=2139, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:48",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Progress - Processed=40\/45, Updated=40, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:48",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=785, Moodle ID=2141, Name=Post class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:49",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=788, Moodle ID=2143, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:49",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=791, Moodle ID=2145, Name=Talk To Me: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:49",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=812, Moodle ID=2164, Name=Pre class loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:49",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Quiz ID=813, Moodle ID=2165, Name=In class Loại 6: Updated successfully",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
{
    "timestamp": "2026-01-02 16:33:49",
    "level": "INFO",
    "function": "updateCompletionMinAttemptsForExerciseQuizzesExec",
    "message": "Process completed - Total=45, Processed=45, Updated=45, Failed=0",
    "memory_usage": "30 MB",
    "peak_memory": "30 MB"
}
