Skip to main content

externalMetaList <Supported_Context_Type, Item_Type>

Serenity/JS Screenplay Pattern-style wrapper around a ChainableMetaQuestion representing a collection that can be resolved in Supported_Context_Type of another Question.

For example, PageElements.located returns MetaList<PageElement>, which allows for the collection of page elements to be resolved in the context of dynamically-provided root element.

import { By, PageElements, PageElement } from '@serenity-js/web'

const firstLabel = () =>
PageElements.located(By.css('label'))
.first()
.describedAs('first label')

const exampleForm = () =>
PageElement.located(By.css('form#example1'))
.describedAs('example form')

const anotherExampleForm = () =>
PageElement.located(By.css('form#example2'))
.describedAs('another example form')

// Next, you can compose the above questions dynamically with various "contexts":
// firstLabel().of(exampleForm())
// firstLabel().of(anotherExampleForm())

Hierarchy

  • List<Item_Type>
    • MetaList

Implements

Index

Constructors

externalconstructor

  • Type parameters

    • Supported_Context_Type
    • Item_Type

    Parameters

    Returns MetaList<Supported_Context_Type, Item_Type>

Methods

externaldescribedAs

  • Changes the description of this object, as returned by Describable.describedBy and Describable.toString.


    Parameters

    • externaldescription: Answerable<string> | MetaQuestion<Item_Type[], Question<Promise<string>>>

      Replaces the current description according to the following rules:

      • If description is an Answerable, it replaces the current description
      • If description is a MetaQuestion, the current description is passed as context to description.of(context), and the result replaces the current description

    Returns this

publicexternalas

  • as<O>(mapping: (answer: Item_Type[]) => O | Promise<O>): QuestionAdapter<O>
  • Maps this question to one of a different type.

    Question.about('number returned as string', actor => '42')   // returns: QuestionAdapter<string>
    .as(Number) // returns: QuestionAdapter<number>

    Type parameters

    • O

    Parameters

    • externalmapping: (answer: Item_Type[]) => O | Promise<O>

    Returns QuestionAdapter<O>

externaldescribedBy

  • Resolves the description of this object in the context of the provided actor.


    Parameters

    Returns Promise<string>

externaltoString

  • toString(): string
  • Returns a human-readable description of this object.


    Returns string

externalforEach

  • forEach(callback: (current: CurrentItem<Item_Type>, index: number, items: Item_Type[]) => void | Promise<void>): Task
  • Parameters

    • externalcallback: (current: CurrentItem<Item_Type>, index: number, items: Item_Type[]) => void | Promise<void>

    Returns Task

externalansweredBy

externalof

  • of(context: Answerable<Supported_Context_Type>): MetaList<Supported_Context_Type, Item_Type>
  • Answers the given ChainableMetaQuestion in the context of another Answerable and returns another ChainableMetaQuestion ready for further chaining.

    Learn more


    Parameters

    • externalcontext: Answerable<Supported_Context_Type>

    Returns MetaList<Supported_Context_Type, Item_Type>

externaleachMappedTo

  • eachMappedTo<Mapped_Item_Type>(question: MetaQuestion<Item_Type, Question<Mapped_Item_Type | Promise<Mapped_Item_Type>>>): MetaList<Supported_Context_Type, Mapped_Item_Type>
  • Type parameters

    • Mapped_Item_Type

    Parameters

    Returns MetaList<Supported_Context_Type, Mapped_Item_Type>

externalwhere

  • Type parameters

    • Answer_Type

    Parameters

    Returns MetaList<Supported_Context_Type, Item_Type>

externalcount

externalfirst

externallast

externalnth

  • Parameters

    • externalindex: number

    Returns MetaQuestionAdapter<Supported_Context_Type, Item_Type>