summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorKirill Rogovoy <[email protected]>2021-07-20 21:24:52 +0300
committerKirill Rogovoy <[email protected]>2021-07-20 21:24:52 +0300
commit5f4611d65e40eae3ca6191a15f68d69ea5a1c4cb (patch)
tree273dfc086444533d86d580961c92ba8d14781a67 /test
parentf0bf4e7afdcd8b02a62be45ab3e7d047ed865a79 (diff)
WIP
Diffstat (limited to 'test')
-rw-r--r--test/i18n.test.ts62
-rw-r--r--test/mock-async-storage.ts3
-rw-r--r--test/mock-file.ts6
-rw-r--r--test/mock-i18n.ts5
-rw-r--r--test/mock-react-native-image.ts20
-rw-r--r--test/mock-reactotron.ts1
-rw-r--r--test/setup.ts13
-rw-r--r--test/storyshots.test.ts6
8 files changed, 0 insertions, 116 deletions
diff --git a/test/i18n.test.ts b/test/i18n.test.ts
deleted file mode 100644
index 913054e..0000000
--- a/test/i18n.test.ts
+++ /dev/null
@@ -1,62 +0,0 @@
-const en = require('../app/i18n/en.json')
-const { exec } = require('child_process')
-
-// Use this array for keys that for whatever reason aren't greppable so they
-// don't hold your test suite hostage by always failing.
-const EXCEPTIONS = [
- // "welcomeScreen.readyForLaunch",
-]
-
-function iterate(obj, stack, array) {
- for (const property in obj) {
- if (Object.prototype.hasOwnProperty.call(obj, property)) {
- if (typeof obj[property] === 'object') {
- iterate(obj[property], `${stack}.${property}`, array)
- } else {
- array.push(`${stack.slice(1)}.${property}`)
- }
- }
- }
-
- return array
-}
-
-/**
- * This tests your codebase for missing i18n strings so you can avoid error strings at render time
- *
- * It was taken from https://gist.github.com/Michaelvilleneuve/8808ba2775536665d95b7577c9d8d5a1
- * and modified slightly to account for our Ignite higher order components,
- * which take 'tx' and 'fooTx' props.
- * The grep command is nasty looking, but it's essentially searching the codebase for 3 things:
- *
- * tx="*"
- * Tx=""
- * translate(""
- *
- * and then grabs the i18n key between the double quotes
- *
- * This approach isn't 100% perfect. If you are storing your key string in a variable because you
- * are setting it conditionally, then it won't be picked up.
- *
- */
-
-describe('i18n', () => {
- test('There are no missing keys', (done) => {
- // Actual command output:
- // grep "Tx=\"\S*\"\|tx=\"\S*\"\|translate(\"\S*\"" -ohr './app' | grep -o "\".*\""
- const command = `grep "Tx=\\"\\S*\\"\\|tx=\\"\\S*\\"\\|translate(\\"\\S*\\"" -ohr './app' | grep -o "\\".*\\""`
- exec(command, (_, stdout) => {
- const allTranslationsDefined = iterate(en, '', [])
- const allTranslationsUsed = stdout.replace(/"/g, '').split('\n')
- allTranslationsUsed.splice(-1, 1)
-
- for (let i = 0; i < allTranslationsUsed.length; i += 1) {
- if (!EXCEPTIONS.includes(allTranslationsUsed[i])) {
- // You can add keys to EXCEPTIONS (above) if you don't want them included in the test
- expect(allTranslationsDefined).toContainEqual(allTranslationsUsed[i])
- }
- }
- done()
- })
- }, 240000)
-})
diff --git a/test/mock-async-storage.ts b/test/mock-async-storage.ts
deleted file mode 100644
index 2b54ced..0000000
--- a/test/mock-async-storage.ts
+++ /dev/null
@@ -1,3 +0,0 @@
-import mockAsyncStorage from '@react-native-async-storage/async-storage/jest/async-storage-mock'
-
-jest.mock('@react-native-async-storage/async-storage', () => mockAsyncStorage)
diff --git a/test/mock-file.ts b/test/mock-file.ts
deleted file mode 100644
index 5dc8d35..0000000
--- a/test/mock-file.ts
+++ /dev/null
@@ -1,6 +0,0 @@
-export default {
- height: 100,
- width: 100,
- scale: 2.0,
- uri: 'https://placekitten.com/200/200',
-}
diff --git a/test/mock-i18n.ts b/test/mock-i18n.ts
deleted file mode 100644
index 9f5038f..0000000
--- a/test/mock-i18n.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-jest.mock('i18n-js', () => {
- return {
- t: (key) => `${key}.test`,
- }
-})
diff --git a/test/mock-react-native-image.ts b/test/mock-react-native-image.ts
deleted file mode 100644
index c01e3ad..0000000
--- a/test/mock-react-native-image.ts
+++ /dev/null
@@ -1,20 +0,0 @@
-import * as ReactNative from 'react-native'
-import mockFile from './mock-file'
-
-jest.doMock('react-native', () => {
- // Extend ReactNative
- return Object.setPrototypeOf(
- {
- Image: {
- ...ReactNative.Image,
- resolveAssetSource: jest.fn((source) => mockFile), // eslint-disable-line @typescript-eslint/no-unused-vars
- getSize: jest.fn((
- uri: string, // eslint-disable-line @typescript-eslint/no-unused-vars
- success: (width: number, height: number) => void,
- failure?: (error: any) => void, // eslint-disable-line @typescript-eslint/no-unused-vars
- ) => success(100, 100)),
- },
- },
- ReactNative,
- )
-})
diff --git a/test/mock-reactotron.ts b/test/mock-reactotron.ts
deleted file mode 100644
index b3bb818..0000000
--- a/test/mock-reactotron.ts
+++ /dev/null
@@ -1 +0,0 @@
-declare const tron // eslint-disable-line @typescript-eslint/no-unused-vars
diff --git a/test/setup.ts b/test/setup.ts
deleted file mode 100644
index 6fe877a..0000000
--- a/test/setup.ts
+++ /dev/null
@@ -1,13 +0,0 @@
-// we always make sure 'react-native' gets included first
-import 'react-native'
-
-// libraries to mock
-import './mock-react-native-image'
-import './mock-async-storage'
-import './mock-i18n'
-import './mock-reactotron'
-
-jest.useFakeTimers()
-declare global {
- let __TEST__
-}
diff --git a/test/storyshots.test.ts b/test/storyshots.test.ts
deleted file mode 100644
index c0a0652..0000000
--- a/test/storyshots.test.ts
+++ /dev/null
@@ -1,6 +0,0 @@
-import initStoryshots from '@storybook/addon-storyshots'
-
-initStoryshots({
- configPath: './storybook',
- framework: 'react-native',
-})