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

Ensure Selenium Test Suite Compatibility with Ubuntu Server Environment #14

Open
shinair opened this issue Mar 28, 2024 · 2 comments
Open
Assignees

Comments

@shinair
Copy link

shinair commented Mar 28, 2024

Describe the problem

The current OpenEMR Selenium Test suit needs changes so it can run headless on the Ubuntu server.

Write a concise description of the problem:
Since the Ubuntu Server is headless, the tests need to run without a GUI. This needs to be specific in the tests in addition to passing a command-line argument while running the Python test file.

Describe the solution you'd like

Make changes to the tests such that they run headless and update the readme.

Write concise description of what feature you want:

  1. The tests should run headless
  2. The readme should reflect the changes accordingly.
@shinair
Copy link
Author

shinair commented Mar 29, 2024

PR that addresses this issue:
Fixed vitals validation bug, modified tests and readme instructions to run on web18 #11
#11

@sunbiz
Copy link
Member

sunbiz commented Dec 15, 2024

@KeerthikaSunchu report.html seems to be exposing the credentials due to the parameters. The ID for each test is exposing all the parameter values, which includes values from secret.json

So, you'd need a function that sanitizes the values when generating the IDs like this:

def sanitize_test_name(param):
    """Create safe test IDs without exposing sensitive data"""
    if isinstance(param, tuple):
        server_name, _, _, _ = param  # Only use server_name for test ID
        return f"server_{server_name}"
    return str(param)

and in any specific test, do like this:

class TestWebsite_vitals:
    @pytest.fixture(autouse=True)
    def browser_setup_and_teardown(self):
        # ... fixture remains the same ...

    @pytest.mark.parametrize(
        "server_name, url, username, password", 
        read_configurations_from_file("secret.json"),
        ids=sanitize_test_name  # Add this to create safe test names
    )

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

No branches or pull requests

3 participants