- A
The policy is missing a condition
Why wrong: Conditions are not required.
- B
The bucket policy explicitly denies the action
An explicit deny in the bucket policy overrides the user policy allow.
- C
The policy does not include s3:GetObject
Why wrong: ListBucket is sufficient to list objects; GetObject is for reading objects.
- D
The policy has a syntax error
Why wrong: The policy is valid JSON.
Quick Answer
The answer is that an explicit deny in the S3 bucket policy overrides the IAM allow. This occurs because AWS authorization logic follows a strict hierarchy: explicit denies always take precedence over any allow, regardless of whether the allow comes from an IAM user policy or a resource-based bucket policy. In this scenario, the IAM policy grants s3:ListBucket, but the bucket policy contains an explicit deny for the same action, which is why the user receives an AccessDenied error. On the AWS Certified Security Specialty SCS-C02 exam, this concept tests your understanding of the "deny override" principle, often appearing as a trick where a seemingly sufficient IAM policy is silently blocked by a bucket policy. A common trap is assuming IAM allows are sufficient without checking resource-based policies. Memory tip: think of explicit deny as a "veto" — no matter how many "yes" votes (allows) you have, one "no" (explicit deny) kills the action.
SCS-C02 Identity and Access Management Practice Question
This SCS-C02 practice question tests your understanding of identity and access management. Match the stated requirement to the specific cloud service, access model, or configuration option — many options are valid in isolation but not for this scenario. After answering, compare your reasoning against the explanation and wrong-answer breakdown below. Once you have made your selection, read the full explanation to reinforce the concept and understand why each distractor is designed to mislead on exam day.
An IAM user receives an 'AccessDenied' error when trying to list objects in an S3 bucket. The user has the following policy attached: {"Version":"2012-10-17","Statement":[{"Effect":"Allow","Action":"s3:ListBucket","Resource":"arn:aws:s3:::example-bucket"}]}. What is the most likely reason?
Clue words in this question
Noticing these words before you look at the options changes how you read each choice.
Clue:
"most likely"Why it matters: Probability qualifier — the question wants the most probable cause or outcome, not a guaranteed one. Eliminate low-probability options.
Answer choices
Why each option matters
Answer the question above first, then reveal the full breakdown to understand why each option is right or wrong.
Correct answer & explanation
The bucket policy explicitly denies the action
The IAM policy grants the s3:ListBucket action on the bucket, which should allow listing objects. However, an explicit deny in a bucket policy overrides any allow, including those from IAM policies. Since the user receives an 'AccessDenied' error, the most likely cause is that the bucket policy explicitly denies the s3:ListBucket action for this user, as explicit denies take precedence over all allows.
Key principle: Answer the scenario, not the keyword: identify the specific constraint before choosing the most familiar-sounding option.
Answer analysis
Option-by-option breakdown
For each option: why learners choose it and why it is or isn't the right answer here.
- ✗
The policy is missing a condition
Why it's wrong here
Conditions are not required.
- ✓
The bucket policy explicitly denies the action
Why this is correct
An explicit deny in the bucket policy overrides the user policy allow.
Clue confirmation
The clue word "most likely" in the question point toward this answer.
Related concept
Read the scenario before looking for a memorised answer.
- ✗
The policy does not include s3:GetObject
Why it's wrong here
ListBucket is sufficient to list objects; GetObject is for reading objects.
- ✗
The policy has a syntax error
Why it's wrong here
The policy is valid JSON.
Common exam traps
Common exam trap: answer the scenario, not the keyword
The trap here is that candidates often assume an IAM policy alone is sufficient and forget that bucket policies can explicitly deny actions, overriding IAM allows, leading them to incorrectly choose options like missing permissions or syntax errors.
Detailed technical explanation
How to think about this question
In AWS IAM, the evaluation logic follows an 'explicit deny overrides allow' rule. When both an IAM policy and a bucket policy apply, the bucket policy can include a Deny statement that explicitly blocks the s3:ListBucket action for a specific principal, which overrides any Allow from the IAM policy. This is a common security pattern to enforce cross-account restrictions or prevent unauthorized listing even if an IAM policy grants it.
KKey Concepts to Remember
- Read the scenario before looking for a memorised answer.
- Find the constraint that changes the correct option.
- Eliminate answers that are true in general but not in this case.
TExam Day Tips
- Watch for words such as best, first, most likely and least administrative effort.
- Review why wrong options are wrong, not only why the correct option is correct.
Key takeaway
Answer the scenario, not the keyword: identify the specific constraint before choosing the most familiar-sounding option.
Real-world example
How this comes up in practice
A media company stores terabytes of video archives that are accessed once a year for audit purposes. Moving these objects to a cold storage tier (Azure Archive, S3 Glacier, or Google Nearline) costs a fraction of hot storage. Questions like this test whether you understand storage tiers, access frequency tradeoffs, and retrieval latency requirements.
What to study next
Got this wrong? Here's your next step.
Identify which exam domain this question belongs to, review the core concept, then practise similar questions from the same domain.
- →
Identity and Access Management — study guide chapter
Learn the concepts, then practise the questions
- →
Identity and Access Management practice questions
Targeted practice on this topic area only
- →
All SCS-C02 questions
1,738 questions across all exam domains
- →
AWS Certified Security Specialty SCS-C02 study guide
Full concept coverage aligned to exam objectives
- →
SCS-C02 practice test guide
How to use practice tests most effectively before exam day
Related practice questions
Related SCS-C02 practice-question pages
Use these pages to review the topic behind this question. This is how one missed question becomes focused revision.
Threat Detection and Incident Response practice questions
Practise SCS-C02 questions linked to Threat Detection and Incident Response.
Security Logging and Monitoring practice questions
Practise SCS-C02 questions linked to Security Logging and Monitoring.
Identity and Access Management practice questions
Practise SCS-C02 questions linked to Identity and Access Management.
Management and Security Governance practice questions
Practise SCS-C02 questions linked to Management and Security Governance.
Infrastructure Security practice questions
Practise SCS-C02 questions linked to Infrastructure Security.
Data Protection practice questions
Practise SCS-C02 questions linked to Data Protection.
SCS-C02 fundamentals practice questions
Practise SCS-C02 questions linked to SCS-C02 fundamentals.
SCS-C02 scenario practice questions
Practise SCS-C02 questions linked to SCS-C02 scenario.
SCS-C02 troubleshooting practice questions
Practise SCS-C02 questions linked to SCS-C02 troubleshooting.
Practice this exam
Start a free SCS-C02 practice session
Short sessions build daily habit. Longer sessions build exam-day stamina. Try a timed session to simulate real conditions.
FAQ
Questions learners often ask
What does this SCS-C02 question test?
Identity and Access Management — This question tests Identity and Access Management — Read the scenario before looking for a memorised answer..
What is the correct answer to this question?
The correct answer is: The bucket policy explicitly denies the action — The IAM policy grants the s3:ListBucket action on the bucket, which should allow listing objects. However, an explicit deny in a bucket policy overrides any allow, including those from IAM policies. Since the user receives an 'AccessDenied' error, the most likely cause is that the bucket policy explicitly denies the s3:ListBucket action for this user, as explicit denies take precedence over all allows.
What should I do if I get this SCS-C02 question wrong?
Identify which exam domain this question belongs to, review the core concept, then practise similar questions from the same domain.
Are there clue words in this question I should notice?
Yes — watch for: "most likely". Probability qualifier — the question wants the most probable cause or outcome, not a guaranteed one. Eliminate low-probability options.
What is the key concept behind this question?
Read the scenario before looking for a memorised answer.
About these practice questions
Courseiva creates original exam-style practice questions with explanations and wrong-answer analysis. It does not publish real exam questions, exam dumps, or protected exam content. Learn why practice questions differ from exam dumps →
Same concept, more angles
1 more ways this is tested on SCS-C02
These questions test the same concept from different angles. Work through them to make sure you can recognise it however the exam phrases it.
Variation 1. A developer is trying to use the AWS CLI to list objects in an S3 bucket but receives an AccessDenied error. The developer has an IAM user with a policy that allows s3:ListBucket on the bucket. What could be causing the error?
easy- A.The developer has not enabled MFA on their IAM user.
- ✓ B.The S3 bucket has a bucket policy that denies access to the developer's IAM user.
- C.The S3 bucket does not exist in the same AWS region as the CLI is configured.
- D.The IAM policy is attached to a group, not directly to the user.
Why B: Option A is correct because even if the IAM policy allows the action, the bucket policy may explicitly deny access. Option B is wrong because MFA is not required unless a condition exists. Option C is wrong because the developer can have multiple policies that combine. Option D is wrong because the bucket exists if the error is AccessDenied.
Last reviewed: Jun 11, 2026
This SCS-C02 practice question is part of Courseiva's free Amazon Web Services certification practice question bank. Courseiva provides original exam-style practice questions with explanations, topic-based practice, mock exams, readiness tracking, and study analytics to help learners prepare for the SCS-C02 exam.
Question Discussion
Share a tip, memory trick, or ask about the reasoning behind this question. Do not post real exam questions, leaked content, braindumps, or copyrighted exam material. Comments are moderated and may be removed without notice.
Sign in to join the discussion.