验证具有 Class="Group0-Item1" Class="Group0-Item2" Class="Group1-Item1" 等属性值的 HTML 元素的顺序

Verify Order Of HTML Elements With Attribute Values Such as Class="Group0-Item1" Class="Group0-Item2" Class="Group1-Item1"

在我的 Selenium/C#/NUNIT 项目中,我需要找到一种方法来验证一组 HTML 元素的顺序(页面 HTML 的自上而下层次结构) (以及这些组中包含的元素)。这些是显示在我页面 HTML...

中的元素
<div class="gapBanner-banner-order1-group0"></div>
<div class="gapBanner-banner-order1-group1"></div>
<div class="gapBanner-banner-order1-group2"></div>
<div class="gapBanner-banner-order2-group2"></div>

我要执行的验证应该能够捕获以下错误:

错误 1:页面 HTML 中的组顺序不正确。 group1 中的元素之一首先出现在 group0 之前的 HTML 中...

<div class="gapBanner-banner-order1-group1"></div>
<div class="gapBanner-banner-order1-group0"></div>
<div class="gapBanner-banner-order1-group2"></div>
<div class="gapBanner-banner-order2-group2"></div>

错误 #2:每个组中的元素在页面 HTML 中的顺序不正确。 Group2-Order2 在 HTML

中出现在 Group2-Order1 之前
<div class="gapBanner-banner-order1-group0"></div>
<div class="gapBanner-banner-order1-group1"></div>
<div class="gapBanner-banner-order2-group2"></div>
<div class="gapBanner-banner-order1-group2"></div>

下面是我到目前为止的编码,但它肯定不会完成这项工作,更不用说,它非常混乱。我不知道我需要什么样的逻辑

            /// 5. Verify the correct order of elements in which they appear inside the HTML
            List<IWebElement> CustomPageHTMLComponents = Browser.
            FindElements(By.XPath("//div[contains(@class, 'group')")).ToList();            
            List<IWebElement> uniqueGroups = new List<IWebElement>();
            // Get the unique groups
        for (int i = 0; i < CustomPageHTMLComponents.Count; i++)
        {
            IWebElement currentComponent = Browser.FindElements(By.XPath("//div[contains(@class, 'group')"))[i];
            string toBeSearched = "group";
            string currentComponenetClassAttributeValue = currentComponent.GetAttribute("class");
            int x = currentComponenetClassAttributeValue.IndexOf(toBeSearched);
            string groupNumber = currentComponenetClassAttributeValue.Substring(x + toBeSearched.Length);

            if (groupNumber == i.ToString())
            {
                uniqueGroups.Add(currentComponent);
            }
        }

             // Some kind of logic to verify everything???
        for (int i = 0; i < Page.CustomPageHTMLComponents.Count; i++)
        {
            IWebElement currentComponent = Browser.FindElements(By.XPath("//div[contains(@class, 'group')"))[i];

            string toBeSearched = "group";
            string currentComponenetClassAttributeValue = currentComponent.GetAttribute("class");
            int x = currentComponenetClassAttributeValue.IndexOf(toBeSearched);
            string groupNumber = currentComponenetClassAttributeValue.Substring(x + toBeSearched.Length);

            Assert.AreEqual(groupNumber, i.ToString());
        }

可能有多种方法可以做到这一点。这是我想出的第一个方法...

  1. 从所需元素中获取所有 class 名称并将它们存储在字符串数组 #1
  2. 复制字符串数组 #1 并对其进行排序
  3. 比较两个数组,如果相等,则从
  4. 开始排序

我已经检查了您提供的 HTML 中您想要捕获的错误,它捕获了所有错误。我能想到的一个问题是,如果你得到超过 9 个 orders 或 groups,排序将不是你想要的,因为它是字母顺序而不是数字顺序,例如1, 10, 2, ... 而不是 1, 2, ... 10.

// capture the class names from the desired classes
string[] elements = _driver.FindElements(By.CssSelector("div[class^='gapBanner-banner-']")).Select(e => e.GetAttribute("class")).ToArray();
// make a copy of the array
string[] sortedElements = new string[elements.Length];
elements.CopyTo(sortedElements, 0);
// sort the copy
Array.Sort(sortedElements);
// compare the arrays for order using NUnit CollectionAssert
CollectionAssert.AreEqual(elements, sortedElements, "Verify ordering of elements");