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

[🐛 Bug]: [rb]: Debug logger initialize gives "wrong number of arguments" #12005

Closed
jorg-vr opened this issue May 8, 2023 · 17 comments
Closed

Comments

@jorg-vr
Copy link

jorg-vr commented May 8, 2023

What happened?

All our tests fail for the new selenium version 4.9.1 (See dodona-edu/dodona#4619)

I traced to root cause to changes made in 1cd84f7

Changing this line https://github.com/SeleniumHQ/selenium/blob/c6f7396f62d02932be0fc3b54846dca12bfa43a6/rb/lib/selenium/webdriver.rb#LL99C42-L99C42 from:

@logger ||= WebDriver::Logger.new('Selenium', default_level: level, **opts)

to

@logger ||= WebDriver::Logger.new(progname: 'Selenium', default_level: level, **opts)

Fixes the issue

How can we reproduce the issue?

Running any of our tests here https://github.com/dodona-edu/dodona/pull/4619 should reproduce.

I am sorry for not making a smaller example, but I think it would fail in almost any example...

Relevant log output

/home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/logger.rb:51:in `initialize': wrong number of arguments (given 2, expected 0..1) (ArgumentError)
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/capybara-3.39.0/lib/capybara/selenium/logger_suppressor.rb:8:in `initialize'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver.rb:99:in `new'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver.rb:99:in `logger'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/service_manager.rb:81:in `build_process'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/service_manager.rb:103:in `start_process'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/service_manager.rb:57:in `block in start'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/socket_lock.rb:42:in `locked'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/service_manager.rb:55:in `start'
	  from <internal:kernel>:90:in `tap'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/service.rb:91:in `launch'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/driver.rb:334:in `service_url'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/local_driver.rb:28:in `initialize_local_driver'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/chrome/driver.rb:34:in `initialize'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/driver.rb:47:in `new'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver/common/driver.rb:47:in `for'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/selenium-webdriver-4.9.1/lib/selenium/webdriver.rb:88:in `for'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/capybara-3.39.0/lib/capybara/selenium/driver.rb:83:in `browser'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/capybara-3.39.0/lib/capybara/selenium/driver.rb:104:in `visit'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/capybara-3.39.0/lib/capybara/session.rb:280:in `visit'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/capybara-3.39.0/lib/capybara/dsl.rb:52:in `call'
	  from /home/jorg/.rvm/gems/ruby-3.1.2/gems/capybara-3.39.0/lib/capybara/dsl.rb:52:in `visit'

Operating System

Linux mint

Selenium version

4.9.1

What are the browser(s) and version(s) where you see this issue?

Not using a browser

What are the browser driver(s) and version(s) where you see this issue?

ChromeDriver 111.0.5563.64

Are you using Selenium Grid?

No response

@github-actions
Copy link

github-actions bot commented May 8, 2023

@jorg-vr, thank you for creating this issue. We will troubleshoot it as soon as we can.


Info for maintainers

Triage this issue by using labels.

If information is missing, add a helpful comment and then I-issue-template label.

If the issue is a question, add the I-question label.

If the issue is valid but there is no time to troubleshoot it, consider adding the help wanted label.

If the issue requires changes or fixes from an external project (e.g., ChromeDriver, GeckoDriver, MSEdgeDriver, W3C), add the applicable G-* label, and it will provide the correct link and auto-close the issue.

After troubleshooting the issue, please add the R-awaiting answer label.

Thank you!

@kennyadsl
Copy link

Same issue here, didn't try if the suggested patch works, though.

@p0deje p0deje added the C-rb label May 8, 2023
@titusfortner
Copy link
Member

This is an issue with how Capybara is wrapping the Selenium Logger. I've submitted a PR for them, and they'll either accept it or get it sorted in another fashion.
teamcapybara/capybara#2665

waiting-for-dev added a commit to solidusio/solidus that referenced this issue May 9, 2023
As a temporary workaround, we're fixing selenium-webdriver to v4.9.0 to
avoid being hit by SeleniumHQ/selenium#12005.
waiting-for-dev added a commit to solidusio/solidus that referenced this issue May 9, 2023
As a temporary workaround, we're fixing selenium-webdriver to v4.9.0 to
avoid being hit by SeleniumHQ/selenium#12005.

[skip ci]
waiting-for-dev added a commit to solidusio/solidus that referenced this issue May 9, 2023
As a temporary workaround, we're fixing selenium-webdriver to v4.9.0 to
avoid being hit by SeleniumHQ/selenium#12005.

[skip ci]
allmarkedup added a commit to lookbook-hq/lookbook that referenced this issue May 10, 2023
allmarkedup added a commit to lookbook-hq/lookbook that referenced this issue May 10, 2023
@kennyadsl
Copy link

Hello, and thanks again for your work on this issue!

I just wanted to point out that this issue is still there, at least until a new version of Capybara is released and looking at teamcapybara/capybara#2666, releasing doesn't seem to be a priority at the moment. Maybe it's worth coordinating with the Capybara maintainers to understand how to move this forward. I'm available to help with that if needed, thanks!

@titusfortner
Copy link
Member

Some people I can't get to be bothered to update off of 5 year old versions. Some people can't stand not to always have the absolute latest versions. 😂

Capybara is a large open source project with a single unpaid maintainer. He'll get to a release when it is convenient for him to do so. The stakes are pretty low on this one. Just limit the version in your gemspec for now.

@kennyadsl
Copy link

I understand your point but sometimes it's not a choice. In our case, we are working on an open-source platform with many plugins (each of them is a gem with a standalone test suite) which are using the last version of selenium-webdriver without locking its patch-level version. Updating all of them (twice, because we need to unlock the dependency once it is fixed) is not ideal.

That said, it's not the end of the world and we can definitely wait. I was just offering my help to speed up things if it was useful/needed.

Thanks again for your work here. 👍

@titusfortner
Copy link
Member

Managing a group of gems is a lot of hassle regardless. Not much to do here in the short term. Long term big picture, finding popular but under resourced open source projects and contributing to them enough to be entrusted with the ability to release them would make a huge difference to the ecosystem.

@titusfortner
Copy link
Member

Actually another thing here. What all is needed for a release? Is the CI passing? Any other bug fixes needed? Is it just a version bump? changelog? If you make a PR that does the drudge work and make it so that all @twalpole needs to do is merge it and run the release command that might be helpful by itself.

@kennyadsl
Copy link

I can definitely prepare the version bump, but since there are other things on the master branch since the last release (including dropping support for Ruby 2.7), I'm not sure what the next version is supposed to be.

@waiting-for-dev
Copy link

Please, let us know if we should move the conversation to the Capybara issue. For now, I'll keep it here as @twalpole has been tagged, and they can tell us the best thing to do.

We were thinking of backporting the bug fix to the latest stable branch and submitting a PR there. However, we realized there's no 3.39_stable branch; instead, the "last" one is 3.38_stable. As we can't create the branch in the repository, we'll happily create the PR if the branch is created. Probably, that would be the best thing to do. A minor release probably needs more considerations, but being a bug fix, a patch release should be enough.

Please, let us know if we can help in any other way, and thanks for your support on this.

@titusfortner
Copy link
Member

Fork the repo, create your own branch and merge whatever and make a PR with it. Worst case he decides to go a different way (essentially what happened with the PR I made). :)

Just getting in the habit of proposing actual code instead of just raising issues makes a huge difference over time.
Open source code is "ours," not "theirs."

@twalpole
Copy link
Contributor

Releasing takes work, and that takes time. Sometimes we value our family time over unpaid work and I would hope people in a well compensated industry would respect that. @titusfortner went out of his way to submit a PR, for which I went with a different solution and will do a new release when I have a few hours to spend on it. If you really need the latest today feel free to use the master branch of Capybara

@waiting-for-dev
Copy link

We have the PR ready to be submitted. But we need the corresponding 3.39_stable branch in the teamcapybara/capybara repository to target that one as the base branch. In the meantime, you can see the corresponding code: teamcapybara/capybara@96a8baa...waiting-for-dev:capybara:v3.39_stable

@codebender
Copy link

Should v4.9.1 get pulled from rubygems? https://rubygems.org/gems/selenium-webdriver/versions/4.9.1

@titusfortner
Copy link
Member

Why? To the extent that there is a bug, it is in Capybara, not Selenium. Capybara is wrapping the class with the wrong signature. Adding an optional keyword parameter to a method should not be considered a breaking change.

One thing we might want to coordinate, @twalpole is that Selenium releases a nightly gem. If Capybara ran tests against that, we can double check things are working before we do a Selenium release in the future. And if anyone on this thread wants to help out with that, I'm sure it would be appreciated by everyone...

@codebender
Copy link

okay understood, it felt like a breaking change because only upgrading the selenium-webdriver caused the bug to surface

waiting-for-dev added a commit to nebulab/solidus that referenced this issue May 22, 2023
This reverts commit f468994.

After the release of capybara 3.39.1 with a fix for the issue for the
newest selenium-webdriver release, there's no longer the need to lock
the later.

See:

- teamcapybara/capybara#2667
- teamcapybara/capybara#2666
- SeleniumHQ/selenium#12005
waiting-for-dev added a commit to nebulab/solidus that referenced this issue May 22, 2023
This reverts commit 9224baf.

After the release of capybara 3.39.1 with a fix for the issue for the
newest selenium-webdriver release, there's no longer the need to lock
the later.

See:

- teamcapybara/capybara#2667
- teamcapybara/capybara#2666
- SeleniumHQ/selenium#12005
Copy link

github-actions bot commented Dec 9, 2023

This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs.

@github-actions github-actions bot locked and limited conversation to collaborators Dec 9, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

7 participants