From b624179b8d7b138c756b98f6c912ae282f7d31c1 Mon Sep 17 00:00:00 2001
From: chris48s <chris48s@users.noreply.github.com>
Date: Mon, 29 Aug 2022 20:58:10 +0100
Subject: [PATCH] get the tests passing on windows (#8350)

* run the core tests on windows

* fix glob with windows path seperator

* always use slash when slicing serviceClass matches

..and add comment explaining why we need to do this

* strip line endings (+ any other whitspace) before base64 encoding

Co-authored-by: repo-ranger[bot] <39074581+repo-ranger[bot]@users.noreply.github.com>
---
 .github/workflows/test-main.yml |  7 ++++++-
 core/base-service/loader.js     | 15 ++++++++++++---
 lib/logos.spec.js               |  4 ++--
 lib/svg-helpers.js              |  4 +++-
 4 files changed, 23 insertions(+), 7 deletions(-)

diff --git a/.github/workflows/test-main.yml b/.github/workflows/test-main.yml
index e07463cd21..e57fdc59a0 100644
--- a/.github/workflows/test-main.yml
+++ b/.github/workflows/test-main.yml
@@ -7,7 +7,12 @@ on:
 
 jobs:
   test-main:
-    runs-on: ubuntu-latest
+    strategy:
+      matrix:
+        os: ['ubuntu-latest', 'windows-latest']
+
+    runs-on: ${{ matrix.os }}
+
     steps:
       - name: Checkout
         uses: actions/checkout@v3
diff --git a/core/base-service/loader.js b/core/base-service/loader.js
index cf499eca15..9bbf0c948d 100644
--- a/core/base-service/loader.js
+++ b/core/base-service/loader.js
@@ -13,6 +13,13 @@ const serviceDir = path.join(
   'services'
 )
 
+function toUnixPath(path) {
+  // glob does not allow \ as a path separator
+  // see https://github.com/isaacs/node-glob/blob/main/changelog.md#80
+  // so we need to convert to use / for use with glob
+  return path.replace(/\\/g, '/')
+}
+
 class InvalidService extends Error {
   constructor(message) {
     super(message)
@@ -22,7 +29,9 @@ class InvalidService extends Error {
 
 async function loadServiceClasses(servicePaths) {
   if (!servicePaths) {
-    servicePaths = glob.sync(path.join(serviceDir, '**', '*.service.js'))
+    servicePaths = glob.sync(
+      toUnixPath(path.join(serviceDir, '**', '*.service.js'))
+    )
   }
 
   const serviceClasses = []
@@ -42,8 +51,8 @@ async function loadServiceClasses(servicePaths) {
       if (serviceClass && serviceClass.prototype instanceof BaseService) {
         // Decorate each service class with the directory that contains it.
         serviceClass.serviceFamily = servicePath
-          .replace(serviceDir, '')
-          .split(path.sep)[1]
+          .replace(toUnixPath(serviceDir), '')
+          .split('/')[1]
         serviceClass.validateDefinition()
         return serviceClasses.push(serviceClass)
       }
diff --git a/lib/logos.spec.js b/lib/logos.spec.js
index 0d6eaae400..cc2e415c72 100644
--- a/lib/logos.spec.js
+++ b/lib/logos.spec.js
@@ -33,7 +33,7 @@ describe('Logo helpers', function () {
   test(prepareNamedLogo, () => {
     // NPM uses multiple colors so the color param should be ignored
     const npmLogo =
-      ''
+      ''
     given({ name: 'npm' }).expect(npmLogo)
     given({ name: 'npm', color: 'blue' }).expect(npmLogo)
 
@@ -115,7 +115,7 @@ describe('Logo helpers', function () {
       undefined
     )
     given('npm', {}).expect(
-      ''
+      ''
     )
   })
 })
diff --git a/lib/svg-helpers.js b/lib/svg-helpers.js
index 040df8a503..c688c34776 100644
--- a/lib/svg-helpers.js
+++ b/lib/svg-helpers.js
@@ -1,5 +1,7 @@
 function svg2base64(svg) {
-  return `data:image/svg+xml;base64,${Buffer.from(svg).toString('base64')}`
+  return `data:image/svg+xml;base64,${Buffer.from(svg.trim()).toString(
+    'base64'
+  )}`
 }
 
 export { svg2base64 }
-- 
GitLab