Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Lager parse transforms produce warnings with the latest Erlang 24 compiler #546

Closed
michaelklishin opened this issue Mar 5, 2021 · 11 comments · Fixed by #547
Closed

Lager parse transforms produce warnings with the latest Erlang 24 compiler #546

michaelklishin opened this issue Mar 5, 2021 · 11 comments · Fixed by #547

Comments

@michaelklishin
Copy link

Filing here per suggestion from @paulo-ferraz-oliveira. @lhoguin suggested this is not really a novel problem for Lager.

See erlang/otp#4576 for the background. The below is true with a very recent Erlang 24 build (I built master with kerl a day ago, for example).

I don't have a way to reproduce this besides this:

source /path/to/kerl/installations/otp-24/activate

git clone https://github.com/rabbitmq/rabbitmq-server.git rabbitmq-monorepo
cd rabbitmq-monorepo
cd deps/rabbit
make

It will eventually produce warnings such as

 ERLC   app_utils.erl code_version.erl credit_flow.erl delegate.erl delegate_sup.erl file_handle_cache.erl file_handle_cache_stats.erl gen_server2.erl lager_forwarder_backend.erl mirrored_supervisor.erl mnesia_sync.erl pmon.erl priority_queue.erl rabbit_amqp_connection.erl rabbit_amqqueue_common.erl rabbit_auth_backend_dummy.erl rabbit_auth_mechanism.erl rabbit_authn_backend.erl rabbit_authz_backend.erl rabbit_basic_common.erl rabbit_binary_generator.erl rabbit_binary_parser.erl rabbit_cert_info.erl rabbit_channel_common.erl rabbit_command_assembler.erl rabbit_control_misc.erl rabbit_core_metrics.erl rabbit_data_coercion.erl rabbit_env.erl rabbit_error_logger_handler.erl rabbit_event.erl rabbit_exchange_type.erl rabbit_framing_amqp_0_8.erl rabbit_framing_amqp_0_9_1.erl rabbit_heartbeat.erl rabbit_http_util.erl rabbit_json.erl rabbit_log.erl rabbit_log_osiris_shim.erl rabbit_log_ra_shim.erl rabbit_misc.erl rabbit_msg_store_index.erl rabbit_net.erl rabbit_nodes_common.erl rabbit_numerical.erl rabbit_password_hashing.erl rabbit_pbe.erl rabbit_peer_discovery_backend.erl rabbit_policy_validator.erl rabbit_queue_collector.erl rabbit_registry.erl rabbit_registry_class.erl rabbit_resource_monitor_misc.erl rabbit_runtime.erl rabbit_runtime_parameter.erl rabbit_semver.erl rabbit_semver_parser.erl rabbit_ssl_options.erl rabbit_types.erl rabbit_writer.erl supervisor2.erl vm_memory_monitor.erl worker_pool.erl worker_pool_sup.erl worker_pool_worker.erl
compile: warnings being treated as errors
src/app_utils.erl:64:29: a term is constructed, but never used
%   64|                             rabbit_log:info("Stopping application '~s'", [App]),
%     |                             ^

rabbit_log is a module which is replaced by Lager parse transforms. Our best lead is that this code produces an expression
which causes the cutting edge Erlang 24 compiler to emit warnings. With -Werror that means things no longer compile.

@michaelklishin
Copy link
Author

I should mention that this is with Lager 3.9.1, so the latest there is.

@paulo-ferraz-oliveira
Copy link
Contributor

Thanks, @michaelklishin. I've seen dialyzer complain about unmatched_returns in our lib.s, but never experienced what you describe. Does it happen with OTP 24-rc1 also?

@michaelklishin
Copy link
Author

No, 24-rc.1 does not reproduce this. Our best guess is that this is new after erlang/otp#4545 was merged.

Since it's not practical for even a moderately sized codebase to explicitly ignore the value returned by the transform-generated code, I'm afraid this has to be addressed in either Lager or erlc.

@michaelklishin
Copy link
Author

Most logging function calls out there probably do not check the returned value. So Lager could assume the value should be ignored by default and introduce another set of functions that do return a value, for those who care enough to check it. I can't think of any other solution right now.

@Vagabond
Copy link
Member

Vagabond commented Mar 5, 2021

I think we should wait for the next RC before trying to address this. Chasing master is not interesting as a bunch of stuff seems to still be in flux there.

@Vagabond
Copy link
Member

Vagabond commented Mar 5, 2021

That said, this is caused by lager returning ok or an error if lager is not running. That error is probably not useful (I don't know if anyone has ever checked that result) so we could have lager calls always return ok even if lager is down.

@paulo-ferraz-oliveira
Copy link
Contributor

Well, I can say that all our code does _ = , but it might not be practical to everybody, I understand.

@paulo-ferraz-oliveira
Copy link
Contributor

That said, this is caused by lager returning ok or an error if lager is not running. That error is probably not useful (I don't know if anyone has ever checked that result) so we could have lager calls always return ok even if lager is down.

When you dialyzer with unmatched_returns you get this. But I can't replicate it yet, for what @michaelklishin is describing.

Do note it's "a term is constructed, but never used" which I've only seen before when we actually have a term that's not matched or returned.

@michaelklishin
Copy link
Author

michaelklishin commented Mar 5, 2021

@Vagabond that's my point. The returned value is never checked and the scenario seems to be only likely early on application boot.

As for "chasing master", that's the only way our team knows with major OTP releases, begin chasing master a couple of months before the release. If we are a couple of weeks late, there will be users who will install the new release and then claim that RabbitMQ is "totally broken".

This is not currently blocking for RabbitMQ because we are switching to OTP logger in master (only to have one less dependency, we generally have been very happy with Lager). It would be great to address this and support OTP 24 in Lager for RabbitMQ 3.8 releases going forward, though :)

@paulo-ferraz-oliveira
Copy link
Contributor

That error is probably not useful (I don't know if anyone has ever checked that result) so we could have lager calls always return ok even if lager is down.

Do you think it acceptable to have an option for this? I'd hate to break previous behaviour.

@paulo-ferraz-oliveira
Copy link
Contributor

As @Vagabond stated, this is solved (I tested it in rabbit directly) by e.g. moving from an {error, _} to ok. I touched the line that states trick the linter into avoiding a 'term constructed but not used' error and well as one other further down which states something similar.

michaelklishin added a commit to Kyorai/cuttlefish that referenced this issue Mar 7, 2021
To work around erlang-lager/lager#546 which blocks
OTP 24 compatibility work in projects that use Lager.

For Cuttlefish, explicitly ignoring return values is a practical
option.
michaelklishin added a commit to rabbitmq/rabbitmq-server that referenced this issue Mar 17, 2021
To work around erlang-lager/lager#546.

The flag was introduced in erlang/otp#4598, which
is more recent than 24-rc.1.
michaelklishin added a commit to rabbitmq/rabbitmq-server that referenced this issue Apr 8, 2021
To work around erlang-lager/lager#546.

The flag was introduced in erlang/otp#4598, which
is more recent than 24-rc.1.
michaelklishin added a commit to rabbitmq/rabbitmq-server that referenced this issue Apr 22, 2021
To work around erlang-lager/lager#546.

The flag was introduced in erlang/otp#4598, which
is more recent than 24-rc.1.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants