Jump into concepts and practice - no test required
or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Recall & Review
beginner
What is a signal handler in Django?
A signal handler is a function that gets called automatically when a specific event (signal) happens in Django, like saving a model or user login.
Click to reveal answer
beginner
How do you connect a signal handler to a signal in Django?
You use the connect() method on the signal, passing the handler function and optionally the sender model to listen for specific events.
Click to reveal answer
intermediate
Why should you connect signal handlers inside the apps.py or a ready method?
Connecting signals in apps.py ensures handlers are registered only once when the app starts, avoiding duplicate calls or missed signals.
Click to reveal answer
intermediate
What does the sender argument do when connecting a signal handler?
The sender argument limits the signal handler to respond only to signals sent by that specific model or class.
Click to reveal answer
beginner
Show a simple example of connecting a signal handler to Django's post_save signal.
from django.db.models.signals import post_save
from django.dispatch import receiver
from myapp.models import MyModel
@receiver(post_save, sender=MyModel)
def my_handler(sender, instance, created, **kwargs):
if created:
print(f"New instance created: {instance}")
Click to reveal answer
What method do you use to connect a signal handler in Django?
Aregister()
Bbind()
Cconnect()
Dattach()
✗ Incorrect
The correct method to connect a signal handler is connect().
Where is the best place to connect signal handlers to avoid multiple registrations?
AInside apps.py in the ready() method
BInside models.py
CInside views.py
DInside templates
✗ Incorrect
Connecting signals inside the ready() method of apps.py ensures handlers are registered once when the app loads.
What does the sender argument specify when connecting a signal?
AThe function to call
BThe model or class sending the signal
CThe signal type
DThe database connection
✗ Incorrect
The sender argument limits the handler to signals sent by a specific model or class.
Which Django signal is commonly used to run code after a model instance is saved?
Apost_save
Bpre_save
Cpre_delete
Dpost_delete
✗ Incorrect
The post_save signal runs after a model instance is saved.
What happens if you connect the same signal handler multiple times?
AIt runs only once
BIt disables the signal
CIt causes an error
DIt runs multiple times for one event
✗ Incorrect
Connecting the same handler multiple times causes it to run multiple times for a single event.
Explain how to connect a signal handler in Django and why it is important to do it in the right place.
Think about app startup and avoiding duplicate calls.
You got /4 concepts.
Describe the role of the sender argument when connecting a signal handler in Django.
Sender is like choosing which friend’s message you want to listen to.
You got /3 concepts.
Practice
(1/5)
1. What is the main purpose of connecting signal handlers in Django?
easy
A. To style HTML templates dynamically
B. To manually call functions from views
C. To create new database tables
D. To automatically run code when certain model events happen
Solution
Step 1: Understand signal handlers
Signal handlers let Django apps respond automatically to events like saving or deleting a model.
Step 2: Identify the purpose
Connecting signal handlers means running code automatically when these events happen, without manual calls.
Final Answer:
To automatically run code when certain model events happen -> Option D
Quick Check:
Signal handlers = automatic event response [OK]
Hint: Signals run code automatically on model events [OK]
Common Mistakes:
Thinking signals create database tables
Confusing signals with manual function calls
Assuming signals style templates
2. Which of the following is the correct way to connect a signal handler using the decorator in Django?
easy
A. @receiver(post_save, sender=MyModel)
def my_handler(sender, instance, **kwargs): pass
B. @signal(post_save, sender=MyModel)
def my_handler(sender, instance): pass
C. @connect(post_save, sender=MyModel)
def my_handler(instance): pass
D. @listen(post_save, sender=MyModel)
def my_handler(sender): pass
Solution
Step 1: Recall the correct decorator
Django uses @receiver to connect signal handlers, not @signal, @connect, or @listen.
Step 2: Check function parameters
The handler must accept sender, instance, and optionally **kwargs. @receiver(post_save, sender=MyModel)
def my_handler(sender, instance, **kwargs): pass matches this.
Final Answer:
@receiver(post_save, sender=MyModel)
def my_handler(sender, instance, **kwargs): pass -> Option A
Quick Check:
Use @receiver with correct params [OK]
Hint: Use @receiver decorator with sender and signal [OK]
Common Mistakes:
Using wrong decorator names
Missing sender argument
Incorrect handler parameters
3. Given this code snippet, what will be printed when a new Book instance is created?
from django.db.models.signals import post_save
from django.dispatch import receiver
@receiver(post_save, sender=Book)
def announce_book(sender, instance, created, **kwargs):
if created:
print(f"New book added: {instance.title}")
book = Book.objects.create(title='Django Basics')
medium
A. New book added:
B. New book added: Django Basics
C. No output
D. Error: missing argument
Solution
Step 1: Understand the signal and handler
The post_save signal triggers after saving a model. The handler checks if created is True, meaning a new record.
Step 2: Analyze the code execution
Creating a new Book instance sets created=True, so the print statement runs with the title.
Final Answer:
New book added: Django Basics -> Option B
Quick Check:
post_save with created=True prints title [OK]
Hint: Check 'created' flag to print on new records only [OK]
Common Mistakes:
Ignoring the 'created' flag
Assuming no output on create
Confusing signal arguments
4. Identify the error in this signal handler connection code:
from django.db.models.signals import post_save
from django.dispatch import receiver
@receiver(post_save)
def handler(sender, instance, **kwargs):
print('Saved!')
medium
A. Missing sender argument in @receiver decorator
B. Handler function missing 'created' parameter
C. post_save signal is not imported correctly
D. Handler function should not have **kwargs
Solution
Step 1: Check the @receiver decorator usage
The @receiver decorator requires the signal and optionally the sender. Omitting sender means the handler listens to all senders, which is allowed but often unintended.
Step 2: Identify the likely error
Since the question asks for an error, the missing sender argument is the problem if the handler is meant for a specific model.
Final Answer:
Missing sender argument in @receiver decorator -> Option A
Quick Check:
Specify sender to target model signals [OK]
Hint: Always specify sender to avoid catching all signals [OK]
Common Mistakes:
Not specifying sender when needed
Assuming 'created' param is always required
Misunderstanding **kwargs usage
5. You want to run a function only when a new UserProfile is created, not when updated. Which is the best way to connect the signal handler?
hard
A. Use @receiver(post_save) without sender and ignore created flag
B. Use @receiver(pre_save, sender=UserProfile) and always run the function
C. Use @receiver(post_save, sender=UserProfile) and check if created is True inside the handler
D. Use @receiver(post_delete, sender=UserProfile) to detect creation
Solution
Step 1: Identify the correct signal for creation
post_save runs after saving, and the created flag tells if it's a new record.
Step 2: Choose the best method
Using @receiver(post_save, sender=UserProfile) and checking created inside the handler ensures the function runs only on creation.
Final Answer:
Use @receiver(post_save, sender=UserProfile) and check if created is True inside the handler -> Option C
Quick Check:
post_save + created=True = run on new only [OK]
Hint: Check 'created' flag in post_save for new records only [OK]