From 73126eab5cdf0b062d4491ed97f74b7353dcfcd7 Mon Sep 17 00:00:00 2001 From: Guy Sartorelli Date: Fri, 27 Jan 2023 15:54:42 +1300 Subject: [PATCH] FIX Emails are arrays Work missed during #232 --- src/Context/EmailContext.php | 27 +++++++++++++-------------- 1 file changed, 13 insertions(+), 14 deletions(-) diff --git a/src/Context/EmailContext.php b/src/Context/EmailContext.php index 78494b61..bef22573 100644 --- a/src/Context/EmailContext.php +++ b/src/Context/EmailContext.php @@ -125,10 +125,10 @@ public function thereTheEmailContains($negate, $content) $email = $this->lastMatchedEmail; $emailContent = null; - if ($email->Content) { - $emailContent = $email->Content; + if ($email['Content']) { + $emailContent = $email['Content']; } else { - $emailContent = $email->PlainContent; + $emailContent = $email['PlainContent']; } if (trim($negate ?? '')) { @@ -154,8 +154,7 @@ public function thereTheEmailContainsPlainText($content) } $email = $this->lastMatchedEmail; - $emailContent = ($email->Content) ? ($email->Content) : ($email->PlainContent); - $emailPlainText = strip_tags($emailContent ?? ''); + $emailPlainText = $email['PlainContent'] ? $email['PlainContent'] : strip_tags($email['Content']); $emailPlainText = preg_replace("/\h+/", " ", $emailPlainText ?? ''); Assert::assertStringContainsString($content, $emailPlainText); @@ -219,7 +218,7 @@ public function iGoToInTheEmail($linkSelector) } $match = $this->lastMatchedEmail; - $crawler = new Crawler($match->Content); + $crawler = new Crawler($match['Content']); $linkEl = $crawler->selectLink($linkSelector); Assert::assertNotNull($linkEl); $link = $linkEl->attr('href'); @@ -254,10 +253,10 @@ public function theEmailContainFollowingData($negate, TableNode $table) $email = $this->lastMatchedEmail; $emailContent = null; - if ($email->Content) { - $emailContent = $email->Content; + if ($email['Content']) { + $emailContent = $email['Content']; } else { - $emailContent = $email->PlainContent; + $emailContent = $email['PlainContent']; } // Convert html content to plain text $emailContent = strip_tags($emailContent ?? ''); @@ -309,9 +308,9 @@ public function theEmailSentFrom($negate, $from) $match = $this->lastMatchedEmail; if (trim($negate ?? '')) { - Assert::assertStringNotContainsString($from, $match->From); + Assert::assertStringNotContainsString($from, $match['From']); } else { - Assert::assertStringContainsString($from, $match->From); + Assert::assertStringContainsString($from, $match['From']); } } @@ -328,9 +327,9 @@ public function theEmailSentTo($negate, $to) $match = $this->lastMatchedEmail; if (trim($negate ?? '')) { - Assert::assertStringNotContainsString($to, $match->To); + Assert::assertStringNotContainsString($to, $match['To']); } else { - Assert::assertStringContainsString($to, $match->To); + Assert::assertStringContainsString($to, $match['To']); } } @@ -348,7 +347,7 @@ public function iClickOnHttpLinkInEmail($httpText) } $email = $this->lastMatchedEmail; - $html = $email->Content; + $html = $email['Content']; $dom = new \DOMDocument(); $dom->loadHTML($html);