2. Which of the following is the correct way to define a background task using the @background decorator in Django?
easy
A. @background def task(): pass
B. @background
def task(): pass
C. def task(): pass @background
D. def task() @background: pass
Solution
Step 1: Recall Python decorator syntax
Decorators are placed on the line above the function with @decorator_name.
Step 2: Check options
@background
def task(): pass correctly places @background on the line above the function definition. Others have syntax errors or wrong order.
Final Answer:
@background
def task(): pass -> Option B
Quick Check:
Decorator above function = A [OK]
Hint: Put @background decorator on line above function [OK]
Common Mistakes:
Placing decorator after function definition
Writing decorator on same line as def
Using invalid syntax like def task() @background
3. Given this code snippet, what will be the output when calling send_email_task('user@example.com') if send_email_task is a background task?
medium
A. The function queues the email to be sent later and returns immediately.
B. The function raises an error because background tasks cannot take arguments.
C. The email is sent immediately and function returns after sending.
D. The function blocks the app until the email is sent.
Solution
Step 1: Understand background task behavior
Background tasks queue work to run later, so the function returns immediately without waiting.
Step 2: Analyze options
The function queues the email to be sent later and returns immediately. matches this behavior. Options A and D describe synchronous behavior. The function raises an error because background tasks cannot take arguments. is incorrect; background tasks can take arguments.
Final Answer:
The function queues the email to be sent later and returns immediately. -> Option A
Quick Check:
Background tasks queue work = C [OK]
Hint: Background tasks queue work and return immediately [OK]
Background tasks need a worker process running to execute queued tasks.
Step 2: Evaluate options
You forgot to start the background task worker process. is the common cause: forgetting to start the worker. Other options describe syntax or design issues but don't prevent task execution as directly.
Final Answer:
You forgot to start the background task worker process. -> Option C
Quick Check:
Worker process must run = B [OK]
Hint: Always start the background task worker to run tasks [OK]
Common Mistakes:
Not running the worker process
Misusing decorator but still expecting task to run
Calling task without parentheses (does nothing)
Defining tasks inside models (not typical but not always blocking)
5. You want to send a welcome email to new users without slowing down the signup page. How should you implement this using Django background tasks?
hard
A. Use @background to create a task that sends the email, then call it after signup.
B. Store the email content in the database and send it manually later.
C. Add a delay in the signup view to simulate sending email later.
D. Send the email directly in the signup view after saving the user.
Solution
Step 1: Identify the goal
The goal is to avoid slowing the signup page by sending email asynchronously.
Step 2: Choose the best approach
Using @background to create a task that sends the email and calling it after signup queues the email sending without blocking the user.
Step 3: Evaluate other options
Send the email directly in the signup view after saving the user. blocks the signup. Add a delay in the signup view to simulate sending email later. delays but still blocks. Store the email content in the database and send it manually later. requires manual work and is not automatic.
Final Answer:
Use @background to create a task that sends the email, then call it after signup. -> Option A
Quick Check:
Use background task for async email = D [OK]
Hint: Use @background task to send email after signup [OK]