transform-react-version-pragma.js — react Source File
Architecture documentation for transform-react-version-pragma.js, a javascript file in the react codebase.
Entity Profile
Relationship Graph
Source Code
'use strict';
const getComments = require('./getComments');
const GATE_VERSION_STR = '@reactVersion ';
const REACT_VERSION_ENV = process.env.REACT_VERSION;
function transform(babel) {
const {types: t} = babel;
// Runs tests conditionally based on the version of react (semver range) we are running
// Input:
// @reactVersion >= 17.0
// test('some test', () => {/*...*/})
//
// Output:
// @reactVersion >= 17.0
// _test_react_version('>= 17.0', 'some test', () => {/*...*/});
//
// See info about semver ranges here:
// https://www.npmjs.com/package/semver
function buildGateVersionCondition(comments) {
if (!comments) {
return null;
}
const resultingCondition = comments.reduce(
(accumulatedCondition, commentLine) => {
const commentStr = commentLine.value.trim();
if (!commentStr.startsWith(GATE_VERSION_STR)) {
return accumulatedCondition;
}
const condition = commentStr.slice(GATE_VERSION_STR.length);
if (accumulatedCondition === null) {
return condition;
}
return accumulatedCondition.concat(' ', condition);
},
null
);
if (resultingCondition === null) {
return null;
}
return t.stringLiteral(resultingCondition);
}
return {
name: 'transform-react-version-pragma',
visitor: {
ExpressionStatement(path) {
const statement = path.node;
const expression = statement.expression;
if (expression.type === 'CallExpression') {
const callee = expression.callee;
switch (callee.type) {
case 'Identifier': {
if (
callee.name === 'test' ||
callee.name === 'it' ||
callee.name === 'fit'
) {
const comments = getComments(path);
const condition = buildGateVersionCondition(comments);
if (condition !== null) {
callee.name =
callee.name === 'fit'
? '_test_react_version_focus'
: '_test_react_version';
expression.arguments = [condition, ...expression.arguments];
} else if (REACT_VERSION_ENV) {
callee.name = '_test_ignore_for_react_version';
}
}
break;
}
case 'MemberExpression': {
if (
callee.object.type === 'Identifier' &&
(callee.object.name === 'test' ||
callee.object.name === 'it') &&
callee.property.type === 'Identifier' &&
callee.property.name === 'only'
) {
const comments = getComments(path);
const condition = buildGateVersionCondition(comments);
if (condition !== null) {
statement.expression = t.callExpression(
t.identifier('_test_react_version_focus'),
[condition, ...expression.arguments]
);
} else if (REACT_VERSION_ENV) {
statement.expression = t.callExpression(
t.identifier('_test_ignore_for_react_version'),
expression.arguments
);
}
}
break;
}
}
}
return;
},
},
};
}
module.exports = transform;
Domain
Subdomains
Functions
Source
Frequently Asked Questions
What does transform-react-version-pragma.js do?
transform-react-version-pragma.js is a source file in the react codebase, written in javascript. It belongs to the BabelCompiler domain, Validation subdomain.
What functions are defined in transform-react-version-pragma.js?
transform-react-version-pragma.js defines 1 function(s): transform.
Where is transform-react-version-pragma.js in the architecture?
transform-react-version-pragma.js is located at scripts/babel/transform-react-version-pragma.js (domain: BabelCompiler, subdomain: Validation, directory: scripts/babel).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free