Skip to content

Commit a176304

Browse files
Running image export bug fixed (#307)
bumping PuppeteerSharp version, add platform specific test files for future use
1 parent 98ce4f2 commit a176304

File tree

7 files changed

+20
-9
lines changed

7 files changed

+20
-9
lines changed

src/Plotly.NET.ImageExport/Plotly.NET.ImageExport.fsproj

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -36,7 +36,7 @@
3636
<ItemGroup>
3737
<PackageReference Include="Plotly.NET" Version="3.*" />
3838
<PackageReference Include="DynamicObj" Version="2.0.0" />
39-
<PackageReference Include="PuppeteerSharp" Version="6.0.0" />
39+
<PackageReference Include="PuppeteerSharp" Version="7.0.0" />
4040
</ItemGroup>
4141

4242
</Project>

src/Plotly.NET.ImageExport/PuppeteerSharpRenderer.fs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@ open DynamicObj
1212
module PuppeteerSharpRendererOptions =
1313

1414
let mutable launchOptions = LaunchOptions()
15+
1516
launchOptions.Timeout <- 60000
1617

1718
let mutable localBrowserExecutablePath =

tests/Plotly.NET.ImageExport.Tests/ImageExport.fs

Lines changed: 16 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1,17 +1,21 @@
11
module Tests.ImageExport
22

3+
open System.Runtime.InteropServices
34
open Expecto
45
open Plotly.NET
56
open Plotly.NET.ImageExport
67

78
open System
89
open System.IO
910

10-
let testBase64JPG = File.ReadAllText (__SOURCE_DIRECTORY__ + "/data/testBase64JPG.txt")
11-
12-
let testBase64PNG =
13-
File.ReadAllBytes(__SOURCE_DIRECTORY__ + "/data/testPNG.png")
14-
|> Convert.ToBase64String
11+
let readTestFilePlatformSpecific filePostfix =
12+
if RuntimeInformation.IsOSPlatform(OSPlatform.Linux) then
13+
let content = File.ReadAllText (__SOURCE_DIRECTORY__ + $"/data/linux{filePostfix}")
14+
content.Substring(0, content.Length - 1) // Because on Linux you're expected to newline terminate the file
15+
else if RuntimeInformation.IsOSPlatform(OSPlatform.Windows) then
16+
File.ReadAllText (__SOURCE_DIRECTORY__ + $"/data/win{filePostfix}")
17+
else
18+
raise (Exception "Running tests on the current OS is not supported :(")
1519

1620
[<Tests>]
1721
let ``Image export tests`` =
@@ -23,21 +27,25 @@ let ``Image export tests`` =
2327
// skipping this for now, cannot make it work atm (pTestAsync -> testAsync for running it)
2428
testList "base64 strings" [
2529
ptestAsync "Chart.toBase64JPGStringAsync" {
30+
let testBase64JPG = readTestFilePlatformSpecific "TestBase64JPG.txt"
31+
2632
let! actual = (Chart.Point([1.,1.]) |> Chart.toBase64JPGStringAsync())
2733

2834
return
29-
Expect.stringContains
35+
Expect.equal
3036
actual
3137
testBase64JPG
3238
"Invalid base64 string for Chart.toBase64JPGStringAsync"
3339
}
3440
ptestAsync "Chart.toBase64PNGStringAsync" {
41+
let testBase64PNG = readTestFilePlatformSpecific "TestBase64PNG.txt"
42+
3543
let! actual = (Chart.Point([1.,1.]) |> Chart.toBase64PNGStringAsync())
3644

3745
return
38-
Expect.stringContains
46+
Expect.equal
3947
actual
40-
testBase64JPG
48+
testBase64PNG
4149
"Invalid base64 string for Chart.toBase64PNGStringAsync"
4250
}
4351
]
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+


tests/Plotly.NET.ImageExport.Tests/data/linuxTestBase64PNG.txt

Lines changed: 1 addition & 0 deletions
Large diffs are not rendered by default.

0 commit comments

Comments
 (0)