@react-native/eslint-plugin-specs
Version:
ESLint rules to validate NativeModule and Component Specs
58 lines (49 loc) • 1.34 kB
JavaScript
/**
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @format
* @oncall react_native
*/
'use strict';
const rule = require('../react-native-modules');
const ESLintTester = require('./eslint-tester.js');
const NATIVE_MODULES_DIR = __dirname;
const eslintTester = new ESLintTester();
const VALID_SPECS = [
{
code: `
import {TurboModuleRegistry, type TurboModule} from 'react-native';
import type {UnsafeObject} from 'react-native/Libraries/Types/CodegenTypes';
export interface Spec extends TurboModule {
func1(a: string): UnsafeObject,
}
export default TurboModuleRegistry.get<Spec>('XYZ');
`,
filename: `${NATIVE_MODULES_DIR}/NativeXYZ.js`,
},
];
const INVALID_SPECS = [
// Untyped NativeModule require
{
code: `
import {TurboModuleRegistry, type TurboModule} from 'react-native';
export interface Spec extends TurboModule {
func1(a: string): {||},
}
export default TurboModuleRegistry.get<Spec>('XYZ');
`,
filename: `${NATIVE_MODULES_DIR}/XYZ.js`,
errors: [
{
message: rule.errors.misnamedHasteModule('XYZ'),
},
],
},
];
eslintTester.run('../react-native-modules', rule, {
valid: VALID_SPECS,
invalid: INVALID_SPECS,
});