Skip to content

Commit

Permalink
(test): ensure styled-components works with TSDX
Browse files Browse the repository at this point in the history
- well, babel-plugin-styled-components fails... but we have a TODO to
  make it work at least!

- ensure styled template tags get converted to regular functions

- add a build-withBabel fixture

(deps): add styled-components, babel-plugin-styled-components
- and it depends on react-dom, react-is
- and needed react-dom and @types/react-dom for the fixture code too
- and @types/styled-components for TS usage
  • Loading branch information
agilgur5 committed Mar 19, 2020
1 parent 643e0b6 commit 81807f7
Show file tree
Hide file tree
Showing 8 changed files with 360 additions and 2 deletions.
6 changes: 6 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -107,19 +107,25 @@
"@types/ora": "^3.2.0",
"@types/ps-tree": "^1.1.0",
"@types/react": "^16.9.11",
"@types/react-dom": "^16.9.5",
"@types/rollup-plugin-json": "^3.0.2",
"@types/rollup-plugin-sourcemaps": "^0.4.2",
"@types/sade": "^1.6.0",
"@types/semver": "^7.1.0",
"@types/styled-components": "^5.0.1",
"autoprefixer": "^9.7.4",
"babel-plugin-styled-components": "^1.10.7",
"cssnano": "^4.1.10",
"doctoc": "^1.4.0",
"husky": "^4.2.2",
"pretty-quick": "^2.0.0",
"ps-tree": "^1.2.0",
"react": "^16.8.6",
"react-dom": "^16.13.0",
"react-is": "^16.13.0",
"rollup-plugin-postcss": "^2.5.0",
"semver": "^7.1.1",
"styled-components": "^5.0.1",
"tiny-invariant": "^1.1.0",
"tiny-warning": "^1.0.3"
},
Expand Down
5 changes: 5 additions & 0 deletions test/integration/fixtures/build-withBabel/.babelrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
module.exports = {
plugins: [
'styled-components'
]
}
7 changes: 7 additions & 0 deletions test/integration/fixtures/build-withBabel/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"scripts": {
"build": "tsdx build"
},
"name": "build-withbabel",
"license": "MIT"
}
8 changes: 8 additions & 0 deletions test/integration/fixtures/build-withBabel/src/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
import './styled.tsx';

export const sum = (a: number, b: number) => {
if ('development' === process.env.NODE_ENV) {
console.log('fuck');
}
return a + b;
};
12 changes: 12 additions & 0 deletions test/integration/fixtures/build-withBabel/src/styled.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import React from 'react';
import ReactDOM from 'react-dom';
import styled from 'styled-components';

const Title = styled.h1`
/* this comment should be removed */
font-size: 1.5em;
text-align: center;
color: palevioletred;
`;

ReactDOM.render(<Title />, document.getElementById('test'));
28 changes: 28 additions & 0 deletions test/integration/fixtures/build-withBabel/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
{
"compilerOptions": {
"module": "ESNext",
"lib": ["dom", "esnext"],
"declaration": true,
"sourceMap": true,
"rootDir": "./src",
"strict": true,
"noImplicitAny": true,
"strictNullChecks": true,
"strictFunctionTypes": true,
"strictPropertyInitialization": true,
"noImplicitThis": true,
"alwaysStrict": true,
"noUnusedLocals": true,
"noUnusedParameters": true,
"noImplicitReturns": true,
"noFallthroughCasesInSwitch": true,
"moduleResolution": "node",
"baseUrl": "./",
"paths": {
"*": ["src/*", "node_modules/*"]
},
"jsx": "react",
"esModuleInterop": true
},
"include": ["src", "types"],
}
51 changes: 51 additions & 0 deletions test/integration/tsdx-build-withBabel.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
const shell = require('shelljs');

const util = require('../util');

shell.config.silent = false;

const testDir = 'integration';
const fixtureName = 'build-withBabel';
const stageName = `stage-integration-${fixtureName}`;

describe('integration :: tsdx build :: .babelrc.js', () => {
beforeAll(() => {
util.teardownStage(stageName);
util.setupStageWithFixture(testDir, stageName, fixtureName);
});

it('should convert styled-components template tags', () => {
let output = shell.exec('node ../dist/index.js build');
expect(output.code).toBe(0);

// from styled.h1` to styled.h1(
output = shell.grep(/styled.h1\(/, ['dist/build-withbabel.*.js']);
expect(output.code).toBe(0);
});

// TODO: make this test work by allowing customization of plugin order
it.skip('should remove comments in the CSS', () => {
// the "should be removed" comment shouldn't be there (gets error code)
const output = shell.grep(/should be removed/, [
'dist/build-withbabel.*.js',
]);
expect(output.code).toBe(1);
});

it('should compile files into a dist directory', () => {
expect(shell.test('-f', 'dist/index.js')).toBeTruthy();
expect(
shell.test('-f', 'dist/build-withbabel.cjs.development.js')
).toBeTruthy();
expect(
shell.test('-f', 'dist/build-withbabel.cjs.production.min.js')
).toBeTruthy();
expect(shell.test('-f', 'dist/build-withbabel.esm.js')).toBeTruthy();

expect(shell.test('-f', 'dist/index.d.ts')).toBeTruthy();
});

afterAll(() => {
util.teardownStage(stageName);
});
});
Loading

0 comments on commit 81807f7

Please sign in to comment.