It seems to be a pretty bad behavior change, why would we do that, what are we trying to achieve?
Instead of a rather clear message "plugin not loaded" the user will start getting obscure "Access denied", which can be caused by a number of reasons. It makes things more difficult for an account admin and more obscure for a user who can't login. What's the gain?
Even worse if you have a "stronger" and a "weaker" account for the same username, e.g. `foo@localhost` and `foo@'%'` (not mentioning anonymous account, which can be declared bad practice). Then, skipping the first one will cause the next one be picked up silently, which can be both unexpected and unwanted.
Making it as bad as skip-name-resolve doesn't seem to be a valid reason. Besides, skip-name-resolve is an active configuration, an admin at least makes it so intentionally (although I wouldn't blame them for not expecting such obscure side-effects). Non-existing plugin is a passive configuration, it's something somebody hasn't done, or even worse, something went wrong on a server/plugin side upon loading the plugin.
A better warning on FLUSH PRIVILEGES won't solve anything, it was just there for simpler reproducing. In reality most problems will happen upon server restart.
On a separate yet related note, how is it going to play along with the planned multiple authentication methods? If you are going to ignore the account completely because the plugin is not loaded, how can other methods be used?
It was an intentional behavior change. Users with non-existing plugins are skipped during the load (just as users with host names if skip-name-resolve is used), so, practically, they don't exist.