Home / Politics / PA's Kenny Kunene...

PA's Kenny Kunene dismisses DA's Helen Zille and ActionSA's Herman Mashaba as non-starters in Johannesburg mayoral race

Left 20% AI estimate Right 20%
South Africa
February 22, 2026 (Updated: March 11, 2026) 2 min read 1 source 0 Center Neutral AI Assisted
PA's Kenny Kunene dismisses DA's Helen Zille and ActionSA's Herman Mashaba as non-starters in Johannesburg mayoral race
AI-Generated Content — Learn More

TheWkly Analysis

Patriotic Alliance’s (PA) deputy president and mayoral candidate for Johannesburg, Kenny Kunene, says he is unfazed by the entry of the Democratic Alliance’s (DA) Helen Zille and ActionSA President Herman Mashaba in the metro’s mayoral race. Kunene was speaking to SABC News on the sidelines of his party’s engagement session with its sitting councillors. He believes he has what it takes to be the city’s mayor. Despite the challenges Johannesburg faces, Kunene believes he knows what must be done to turn the country’s richest city around. The Patriotic Alliance’s deputy president is positioning himself as the right person to lead Johannesburg.

Multiple perspectives analyzed from 0 sources
What this means for you:
  • Johannesburg residents gain improved city services if Kunene wins, with better infrastructure turning around utilities for 5.5 million people.
  • DA and ActionSA supporters face prolonged opposition struggles, delaying their policy influence on crime reduction and economic reforms in the metro.
  • PA councillors secure stronger bargaining power in coalitions, enhancing job security and resources for their community-focused initiatives.
Your Wallet
This South African political spat over Johannesburg's mayor won't directly hit your wallet or job here in the US, since it's a local race far from our shores. But if it leads to ongoing city drama, it could stir up instability in South Africa's economy, potentially raising global prices for gold, platinum, or other exports that bump up costs for cars, jewelry, or electronics you buy. For most young Americans, it's business as usual—your daily expenses and savings stay untouched unless you're heavily into international investments.

Key Entities

  • Kenny Kunene Person

    Deputy president of the Patriotic Alliance and mayoral candidate for Johannesburg, expressing confidence in leading the city.

  • Patriotic Alliance (PA) Organization

    South African political party with Kunene as deputy president, fielding him as Johannesburg mayoral candidate.

  • Helen Zille Person

    Democratic Alliance figure entering the Johannesburg mayoral race, dismissed by Kunene as a non-starter.

  • Herman Mashaba Person

    ActionSA president and Johannesburg mayoral contender, viewed unfazed by Kunene.

  • Johannesburg Place

    South Africa's richest city facing challenges, at the center of the mayoral contest.

Multi-Perspective Analysis

Left-Leaning View

Frames opposition challengers as disruptive to ANC-aligned governance, downplaying their credentials while highlighting PA's local engagement.

Centrist View

Reports straightforwardly on candidates' statements and context, allowing readers to assess without overt favoritism.

Right-Leaning View

Emphasizes PA's confidence against established DA figures, portraying Kunene as a bold outsider ready to fix systemic failures.

Source & Verification

Source: SABC News RSS

Status: AI Processed

Want to dive deeper?

We've prepared an in-depth analysis of this story with additional context and background.

Featuring Our Experts' Perspectives in an easy-to-read format.

Future Snapshot

See how this story could impact your life in the coming months

Sign In to Generate

Exclusive Member Feature

Create a free account to access personalized Future Snapshots

Future Snapshots show you personalized visions of how insights from this story could positively impact your life in the next 6-12 months.

  • Tailored to your life indicators
  • Clear next steps and action items
  • Save snapshots to your profile

Related Roadmaps

Explore step-by-step guides related to this story, designed to help you apply this knowledge in your life.

Loading roadmaps...

Please wait while we find relevant roadmaps for you.

Your Opinion

Who is best suited to lead Johannesburg as mayor?

Your feedback helps us improve our content.

Support Independent Journalism

If you found this story valuable, consider supporting TheWkly to help us continue delivering quality news.

Comments (0)

Add your comment

Commenting as Guest

No comments yet. Be the first to share your thoughts!

Related Stories

President José María Balcázar meets Puno Regional Government authorities on urgent demands of least affluent districts
Politics March 11, 2026

President José María Balcázar meets Puno Regional Government authorities on urgent demands of least affluent districts

The President of the Republic, José María Balcázar, met today with authorities from the Puno...

Disinformation campaign shaped narrative of election engineering in Bangladesh's 2026 parliamentary election
Politics March 11, 2026

Disinformation campaign shaped narrative of election engineering in Bangladesh's 2026 parliamentary election

Bangladesh’s 2026 parliamentary election unfolded within an information landscape fundamentally...

Rights groups urge Bangladesh to review cases of jailed journalists for press freedom
Politics March 11, 2026

Rights groups urge Bangladesh to review cases of jailed journalists for press freedom

Rights groups and media organizations are urging the Bangladesh government to review politically...

Share this story
// Function to create a roadmap using our consolidated approach function createRoadmap(storyId) { // Show a loading indicator const loadingHtml = `

Creating your roadmap...

This may take a moment

`; document.body.insertAdjacentHTML('beforeend', loadingHtml); // Make the API call to create the roadmap using the enhanced unified approach fetch(`/api/roadmaps/create/${storyId}`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'X-CSRFToken': 'IjFkYjhkNGM3Y2Q2YjYxYmFjOTY3Y2YwNzk4OGFkOWJlMGM3N2IyY2Mi.abEIQg.7rDXM2BS66DwnulA8ZqFsVHXLDI' } }) .then(response => response.json()) .then(data => { // Remove the loading indicator document.getElementById('loading-overlay').remove(); if (data.success) { // Show success message const successHtml = `

Roadmap Created!

Your learning path has been successfully created.

`; document.body.insertAdjacentHTML('beforeend', successHtml); } else { // Show error message const errorHtml = `

Error

${data.message || 'An error occurred while creating the roadmap.'}

`; document.body.insertAdjacentHTML('beforeend', errorHtml); } }) .catch(error => { // Remove the loading indicator document.getElementById('loading-overlay').remove(); // Show error message const errorHtml = `

Error

An unexpected error occurred. Please try again later.

`; document.body.insertAdjacentHTML('beforeend', errorHtml); console.error('Error creating roadmap:', error); }); } document.addEventListener('DOMContentLoaded', function() { // Auto-mark as read after 10 seconds // Function to load related roadmaps function loadRelatedRoadmaps() { // Load related roadmaps for this story console.log('Loading related roadmaps for story ID: 16172'); fetch('/api/stories/16172/related-roadmaps') .then(response => { if (!response.ok) { throw new Error(`HTTP error! Status: ${response.status}`); } return response.json(); }) .then(data => { console.log('Related roadmaps API response:', data); const container = document.getElementById('roadmaps-container'); if (!container) { console.error('Roadmaps container not found in DOM'); return; } // Clear the loading indicator container.innerHTML = ''; if (data.roadmaps && data.roadmaps.length > 0) { console.log(`Found ${data.roadmaps.length} roadmaps to display`); // Render each roadmap card data.roadmaps.forEach(roadmap => { console.log(`Processing roadmap ID ${roadmap.id}: ${roadmap.title}`); const card = document.createElement('div'); card.className = 'p-4 bg-white rounded-lg border border-blue-200 hover:shadow-md transition-shadow'; let iconType = 'map'; if (roadmap.type === 'career') iconType = 'briefcase'; else if (roadmap.type === 'personal') iconType = 'user'; else if (roadmap.type === 'learning') iconType = 'graduation-cap'; else if (roadmap.type === 'financial') iconType = 'chart-line'; card.innerHTML = `

${roadmap.title}

${roadmap.description || 'Interactive step-by-step guide'}

${roadmap.step_count ? ` ${roadmap.step_count} steps` : ''} ${roadmap.created_by ? ` ${roadmap.created_by}` : ''}
`; container.appendChild(card); }); } else { console.log('No roadmaps found for this story'); // Show "no roadmaps" message with different content for logged in vs not logged in users const isLoggedIn = false; if (isLoggedIn) { container.innerHTML = `

No roadmaps found for this story yet.

Be the first to create one!

`; } else { container.innerHTML = `

Create your own roadmaps!

Sign up to create interactive step-by-step guides for this story and others.

`; } } }) .catch(error => { console.error('Error loading roadmaps:', error); const container = document.getElementById('roadmaps-container'); if (container) { container.innerHTML = `

Unable to load roadmaps at this time.

Error: ${error.message}

`; } }); } // Load roadmaps when page loads loadRelatedRoadmaps(); // Check for "roadmap_created" or "roadmap_updated" URL parameter and reload roadmaps if present const urlParams = new URLSearchParams(window.location.search); if (urlParams.has('roadmap_created') || urlParams.has('roadmap_updated')) { // Small delay to ensure the UI is ready setTimeout(loadRelatedRoadmaps, 500); } // Add event listeners to roadmap creation links to append return parameters document.querySelectorAll('a[href*="create_roadmap_from_story"], a[href*="create-roadmap-from-plan"]').forEach(link => { link.addEventListener('click', function(e) { // Store the current URL to return to this page const returnUrl = window.location.href.split('?')[0] + '?roadmap_created=true'; // Store in sessionStorage sessionStorage.setItem('roadmapReturnUrl', returnUrl); }); }); // Handle reaction buttons const reactionButtons = document.querySelectorAll('.reaction-btn'); reactionButtons.forEach(button => { button.addEventListener('click', function() { const reaction = this.dataset.reaction; const storyId = this.dataset.storyId; // Send reaction to server fetch(`/api/stories/${storyId}/reactions`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'X-CSRFToken': 'IjFkYjhkNGM3Y2Q2YjYxYmFjOTY3Y2YwNzk4OGFkOWJlMGM3N2IyY2Mi.abEIQg.7rDXM2BS66DwnulA8ZqFsVHXLDI' }, body: JSON.stringify({ reaction_type: reaction }) }) .then(response => response.json()) .then(data => { if (data.success) { // Toggle active state if (data.added) { this.classList.add('border-blue-500', 'bg-blue-50', 'text-blue-700'); } else { this.classList.remove('border-blue-500', 'bg-blue-50', 'text-blue-700'); } // Update count if available const countElement = this.querySelector('.reaction-count'); if (data.count > 0) { if (countElement) { countElement.textContent = `(${data.count})`; } else { const countSpan = document.createElement('span'); countSpan.className = 'reaction-count'; countSpan.textContent = `(${data.count})`; const textElement = this.querySelector('span:not(.text-lg)'); textElement.appendChild(countSpan); } } else if (countElement) { countElement.remove(); } } }) .catch(error => { console.error('Error updating reaction:', error); }); }); }); });