Manca una clausola GROUP BY:
SELECT news.id, users.username, news.title, news.date, news.body, COUNT(comments.id)
FROM news
LEFT JOIN users
ON news.user_id = users.id
LEFT JOIN comments
ON comments.news_id = news.id
GROUP BY news.id
Il join sinistro è corretto. Se hai utilizzato un INNER o un RIGHT JOIN, non avresti ricevuto notizie senza commenti.