- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于上下文,我们有一个 Angular + Nx monorepo,目前只有一个主要的 app
,但我们计划很快将其拆分为几个独立的微前端。
我们目前只有一个主要模块,util-models
,它包含所有描述所有 API 交互的接口(interface),以及< em>所有 我们在测试中用来模拟数据的 stub 。
现在假设我有一个库 my-feature
,其中包含一些我想要构建和部署的功能(作为延迟加载的路由或作为主包的一部分)。这个库已经依赖于 util-models
,因为它处理一些标准化数据,但我们还有一个单独的 my-model.model.ts
文件,它只描述接口(interface)特定于此功能。
一些视觉表现:
\my-feature
\lib
- my-models.model.ts
- my-component.component.ts
- my-component.component.spec.ts
\util-models
\lib
- shared-model.model.ts
\test
- shared-model.stub.ts
所以问题是,我应该将包含所有库特定 stub 的 my-models.stub.ts
文件放在哪里?
1.第一个明显的答案似乎是“将特定于库的代码放入库中”。但这是否意味着我所有的库实际上应该旨在为所有 stub 或特定于它们的测试实用程序创建一个单独的 test
目录?这是否也适用于模型(甚至不是可编译代码,只是接口(interface))?这不会降低这些本应帮助开发人员的工具的可发现性,以防将来其他一些库实际上也在处理相同的数据结构吗?
此外,此代码是否会与常规 .spec.ts
文件一起从产品构建中自动删除?仅仅不将其导入到 module
中就足够了吗?
2。另一种选择是将它放在已经存在的 util-models
库中,my-feature
可能会继续依赖它,但显然我担心这只会减少它长期分开。另一方面,如果这只是测试永远不会投入生产的代码,那么也许这实际上很好,或者出于某种原因甚至是可取的?
我最感兴趣的是这两个选项可能会如何影响构建/测试构建时间、tree shaking、延迟加载和迁移到微前端等事情。如果有任何提示,我将不胜感激!
最佳答案
我还没有找到任何官方文档来解决这个问题,但是在花更多时间使用 Nx 之后,尤其是在了解更多关于 DDD(领域驱动开发)之后,我变得更加直觉.
我目前的直觉是,实际上不相关的库之间代码的“可发现性”不是一个特性,而是一个问题。所有代码都应该属于它自己的特定领域,而不是集中在某个大型通用库中——它只是接口(interface)或测试代码都没有关系。
每个“共享”库,如果我们允许它存在于我们的依赖树中,则必须有一个至多特定于一个域的目的。
因此,我现在对以下决定充满信心:
util-models
库。描述 API 响应的模型都可以分配给更具体的域。test
目录,以便在我们想要测试我们的组件/服务/等时准备好模型 stub 。在那个图书馆。关于angular - 在 Nx + Angular monorepo 架构中,我应该在哪里放置特定于一个库的测试助手?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71785098/
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 去年关闭。 Improve th
想要从 nx 10 工作区移动到 12 而不离开角度 10。 nx migrate latest 但是升级也会默认升级 angular。 我搜索了 https://nx.dev/previous/an
我只是想知道为 monorepo 设置配置 codecov 的最佳方法是什么。例如,假设我的 monorepo 下有包 A 和 B。我目前使用 codecov 的方式是使用 github 操作 cod
我的 monorepo 中有以下文件结构 📦monorepo ┣ 📂node_modules ┣ 📂packages ┃ ┣ 📂package-1 ┃ ┃ ┗ 📜jest.confi
我有一个根据本教程设置的 monorepo:tutorial . 该项目由一个包含三个包的主文件夹 (series4) 组成,这三个包专注于 web、移动应用程序和通用代码 - 它们分别命名为 web
随着前端工程日益复杂,某些业务或者工具库通常涉及到很多个仓库,那么时间一长,多个仓库开发弊端日益显露,由此出现了一种新的项目管理方式——Monorepo。本文主要以 Monorepo 的概念、M
Canvas简历编辑器-Monorepo+Rspack工程实践 在之前我们围绕Canvas聊了很多代码设计层面的东西,在这里我们聊一下工程实践。在之前的文中我也提到过,因为是本着学习的态度以及对技术
我一直在网上搜索解决方案,但没有找到任何有值(value)的东西。基本上,我正在寻找一种工具或某种方式来同时在多个目录中启动 TypeScript 文件监视/编译。 我有一个带有作用域 NPM 包(@
假设我对 Javascript monorepo 有以下限制 -- module a package.json -- module b package.json package.json
在 monorepo 中,如果您在一个包中有依赖项,您可以在另一个包中使用该依赖项而不将其添加到该包中吗?为了更清楚,请检查以下布局。 Project |-packages |-
在我们的项目中,我们在整个公司中使用了多个 monorepos。问题是,例如我们有 monorepo-A 和 monorepo-B,而 monorepo-B 使用来自 monorepo-A 的组件(这
当 monorepo 中的包具有对等依赖项时,在开发过程中应该如何使这些依赖项对它们可用? 例如 /packages/namespace/alpha/ 的包裹可能有 devDependency的 st
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 5 年前。 Improve this ques
我们最近决定从 TFVC 迁移到 Git,我正在努力寻找设计新 Git 架构的最佳方法。 我们的代码由独立但紧密耦合的模块组成,让我们看看以下项目: CommonLib1 CommonLib2 App
在 monorepos 中是否有使用版本标签的标准? 1.0.0-myapp1 和 2.1.0-myapp2 是否可以接受?还是有另一种方法来区分应用程序之间的版本? 最佳答案 tags被组织在目录和
我们想在库和我们的应用程序中使用 @emotion/react 中的 useTheme 我们正在使用:-react-native-web-nx 单体仓库- native react 这是我们的结构
我有一个使用 lerna 和 yarn 工作区的 monorepo 用于前端应用程序和库。我在根 package.json 中添加了一系列 npm 脚本,以管理每个包(应用程序、库、插件),就像本文末
我们有一个代码库已经被多个项目堵塞了——所以它现在是一个单一代码库。 我们需要将多个文件夹连同它们的历史一起分解成新的存储库。即: Current repo "Monorepo" folders:
我正在开发一个由多个 git 存储库组成的项目。有多个微服务、一个前端、一些 npm 包和网关容器等。 由于我经常遇到这样的问题,即对于新功能,我必须更改多个存储库中的代码,我会在很多 pull 请求
我在 GitLab 中有一个使用 Feature Branch 方法的 monorepo。 我想要实现的是启动与包含更改文件的目录相关联的管道部分。所以我的 .gitlab-ci.yml 看起来像:
我是一名优秀的程序员,十分优秀!