The nightly test test_pwpolicy.py::test_pwpolicy::test_misc is failing, see PR #491 with the following report:
test_pwpolicy.py::test_pwpolicy::test_misc
self = <ipatests.test_webui.test_pwpolicy.test_pwpolicy object at 0x7f8a678a21f0> @screenshot def test_misc(self): """ various test cases covered in one place """ # Basic requirement : create user group for test self.init_app() self.navigate_to_entity(group.ENTITY) self.add_record(group.ENTITY, [group.DATA, group.DATA2, group.DATA3, group.DATA_SPECIAL_CHAR_GROUP]) # add then cancel self.add_record(pwpolicy.ENTITY, pwpolicy.DATA1, dialog_btn='cancel') # test add and add another record self.add_record(pwpolicy.ENTITY, [pwpolicy.DATA1, pwpolicy.DATA2]) # test add and edit record self.add_record(pwpolicy.ENTITY, pwpolicy.DATA, dialog_btn='add_and_edit') # test delete multiple records self.navigate_to_entity(pwpolicy.ENTITY) records = [pwpolicy.DATA, pwpolicy.DATA1, pwpolicy.DATA2] self.select_multiple_records(records) self.facet_button_click('remove') self.dialog_button_click('ok') # test add password policy for special characters group self.add_record(pwpolicy.ENTITY, pwpolicy.DATA_SPECIAL_CHAR, delete=True) # empty group and priority (requires the field) self.facet_button_click('add') self.dialog_button_click('add') self.assert_field_validation_required(field='cn') self.assert_field_validation_required(field='cospriority') self.close_all_dialogs() # test delete default policy and # confirming by keyboard to test ticket #4097 > self.select_record(pwpolicy.DEFAULT_POLICY) test_webui/test_pwpolicy.py:96: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ test_webui/ui_driver.py:1182: in select_record checkbox = self.find(input_s, By.CSS_SELECTOR, parent, strict=True) test_webui/ui_driver.py:129: in wrapped return fn(*args, **kwargs) test_webui/ui_driver.py:310: in find result = func(by, expression) /usr/local/lib/python3.8/site-packages/selenium/webdriver/remote/webelement.py:658: in find_element return self._execute(Command.FIND_CHILD_ELEMENT, /usr/local/lib/python3.8/site-packages/selenium/webdriver/remote/webelement.py:633: in _execute return self._parent.execute(command, params) /usr/local/lib/python3.8/site-packages/selenium/webdriver/remote/webdriver.py:321: in execute self.error_handler.check_response(response) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <selenium.webdriver.remote.errorhandler.ErrorHandler object at 0x7f8a678a2e20> response = {'status': 404, 'value': '{"value":{"error":"no such element","message":"Unable to locate element: table.table tbody t...ror@chrome://marionette/content/error.js:387:5\\nelement.find/</<@chrome://marionette/content/element.js:330:16\\n"}}'} def check_response(self, response): """ Checks that a JSON response from the WebDriver does not have an error. :Args: - response - The JSON response from the WebDriver server as a dictionary object. :Raises: If the response contains an error message. """ status = response.get('status', None) if status is None or status == ErrorCode.SUCCESS: return value = None message = response.get("message", "") screen = response.get("screen", "") stacktrace = None if isinstance(status, int): value_json = response.get('value', None) if value_json and isinstance(value_json, basestring): import json try: value = json.loads(value_json) if len(value.keys()) == 1: value = value['value'] status = value.get('error', None) if status is None: status = value["status"] message = value["value"] if not isinstance(message, basestring): value = message message = message.get('message') else: message = value.get('message', None) except ValueError: pass exception_class = ErrorInResponseException if status in ErrorCode.NO_SUCH_ELEMENT: exception_class = NoSuchElementException elif status in ErrorCode.NO_SUCH_FRAME: exception_class = NoSuchFrameException elif status in ErrorCode.NO_SUCH_WINDOW: exception_class = NoSuchWindowException elif status in ErrorCode.STALE_ELEMENT_REFERENCE: exception_class = StaleElementReferenceException elif status in ErrorCode.ELEMENT_NOT_VISIBLE: exception_class = ElementNotVisibleException elif status in ErrorCode.INVALID_ELEMENT_STATE: exception_class = InvalidElementStateException elif status in ErrorCode.INVALID_SELECTOR \ or status in ErrorCode.INVALID_XPATH_SELECTOR \ or status in ErrorCode.INVALID_XPATH_SELECTOR_RETURN_TYPER: exception_class = InvalidSelectorException elif status in ErrorCode.ELEMENT_IS_NOT_SELECTABLE: exception_class = ElementNotSelectableException elif status in ErrorCode.ELEMENT_NOT_INTERACTABLE: exception_class = ElementNotInteractableException elif status in ErrorCode.INVALID_COOKIE_DOMAIN: exception_class = InvalidCookieDomainException elif status in ErrorCode.UNABLE_TO_SET_COOKIE: exception_class = UnableToSetCookieException elif status in ErrorCode.TIMEOUT: exception_class = TimeoutException elif status in ErrorCode.SCRIPT_TIMEOUT: exception_class = TimeoutException elif status in ErrorCode.UNKNOWN_ERROR: exception_class = WebDriverException elif status in ErrorCode.UNEXPECTED_ALERT_OPEN: exception_class = UnexpectedAlertPresentException elif status in ErrorCode.NO_ALERT_OPEN: exception_class = NoAlertPresentException elif status in ErrorCode.IME_NOT_AVAILABLE: exception_class = ImeNotAvailableException elif status in ErrorCode.IME_ENGINE_ACTIVATION_FAILED: exception_class = ImeActivationFailedException elif status in ErrorCode.MOVE_TARGET_OUT_OF_BOUNDS: exception_class = MoveTargetOutOfBoundsException elif status in ErrorCode.JAVASCRIPT_ERROR: exception_class = JavascriptException elif status in ErrorCode.SESSION_NOT_CREATED: exception_class = SessionNotCreatedException elif status in ErrorCode.INVALID_ARGUMENT: exception_class = InvalidArgumentException elif status in ErrorCode.NO_SUCH_COOKIE: exception_class = NoSuchCookieException elif status in ErrorCode.UNABLE_TO_CAPTURE_SCREEN: exception_class = ScreenshotException elif status in ErrorCode.ELEMENT_CLICK_INTERCEPTED: exception_class = ElementClickInterceptedException elif status in ErrorCode.INSECURE_CERTIFICATE: exception_class = InsecureCertificateException elif status in ErrorCode.INVALID_COORDINATES: exception_class = InvalidCoordinatesException elif status in ErrorCode.INVALID_SESSION_ID: exception_class = InvalidSessionIdException elif status in ErrorCode.UNKNOWN_METHOD: exception_class = UnknownMethodException else: exception_class = WebDriverException if value == '' or value is None: value = response['value'] if isinstance(value, basestring): if exception_class == ErrorInResponseException: raise exception_class(response, value) raise exception_class(value) if message == "" and 'message' in value: message = value['message'] screen = None if 'screen' in value: screen = value['screen'] stacktrace = None if 'stackTrace' in value and value['stackTrace']: stacktrace = [] try: for frame in value['stackTrace']: line = self._value_or_default(frame, 'lineNumber', '') file = self._value_or_default(frame, 'fileName', '<anonymous>') if line: file = "%s:%s" % (file, line) meth = self._value_or_default(frame, 'methodName', '<anonymous>') if 'className' in frame: meth = "%s.%s" % (frame['className'], meth) msg = " at %s (%s)" msg = msg % (meth, file) stacktrace.append(msg) except TypeError: pass if exception_class == ErrorInResponseException: raise exception_class(response, message) elif exception_class == UnexpectedAlertPresentException: alert_text = None if 'data' in value: alert_text = value['data'].get('text') elif 'alert' in value: alert_text = value['alert'].get('text') raise exception_class(message, screen, stacktrace, alert_text) > raise exception_class(message, screen, stacktrace) E selenium.common.exceptions.NoSuchElementException: Message: Unable to locate element: table.table tbody td input[value='global_policy']
The test fails when trying to delete the default password policy global_policy because it doesn't find this policy.
global_policy
@rcritten could you check if the new failure is related to the commit of libpwquality (PR #5160)? Thanks
It's failing because it is missing the ipapwdpolicy objectclass. For backwards compatibility this shouldn't be included in the filter.
Metadata Update from @rcritten: - Issue assigned to rcritten
On second thought let's add the missing objectclass on upgrade. It won't hurt existing installs.
https://github.com/freeipa/freeipa/pull/5208
Metadata Update from @rcritten: - Custom field rhbz adjusted to https://bugzilla.redhat.com/show_bug.cgi?id=1340463 https://bugzilla.redhat.com/show_bug.cgi?id=1442413
master:
ipa-4-8:
Metadata Update from @rcritten: - Issue close_status updated to: fixed - Issue status updated to: Closed (was: Open)
Login to comment on this ticket.