Project Icon

spring-data-build

Spring Data模块的通用构建基础设施

spring-data-build为Spring Data模块提供统一的构建基础设施。它包含resources和parent两个子项目,简化了Maven项目的配置过程。该项目预设了核心依赖、属性和文档生成,并支持JavaDoc打包、文档生成和模式文件分发等任务。spring-data-build适用于单模块和多模块项目,是Apache 2.0许可的开源项目。

= Spring Data 构建基础设施 image:https://jenkins.spring.io/buildStatus/icon?job=spring-data-build%2Fmain&subject=Build[link=https://jenkins.spring.io/view/SpringData/job/spring-data-build/] image:https://img.shields.io/badge/Revved%20up%20by-Develocity-06A0CE?logo=Gradle&labelColor=02303A["Revved up by Develocity", link="https://ge.spring.io/scans?search.rootProjectNames=Spring Data Build"]

该存储库包含用于使用 Maven 构建的 Spring Data 模块的通用基础设施。它由一个 resources 项目组成,该项目打包了构建过程中需要的资源,包括用于生成参考文档和 JavaDoc 的 CSS。第二个项目是 parent,可以用作父项目来预配置核心依赖项、属性、参考文档生成,最重要的是适当的分发程序集。

父项目可以用于单模块 Maven 项目或多模块项目。每种设置都需要对项目进行略微不同的配置。

== 行为准则

本项目遵循 link:https://github.com/spring-projects/.github/blob/main/CODE_OF_CONDUCT.md[Spring 行为准则]。通过参与,您应当遵守此行为准则。如遇不可接受的行为,请向 spring-code-of-conduct@pivotal.io 报告。

== 项目设置

=== 通用设置

父项目配置了项目构建的以下方面:

spring-data-build-resources 依赖中引入共享资源(图像、CSS、JavaScript)。从 src/asciidoc 目录中名为 index.adoc 的 Asciidoc 文件渲染参考文档。在 distribute 配置文件中,生成两个程序集:一个 ZIP 文件上传到 docs.spring.io(包括可浏览的 javadoc、如前所述的参考文档),内容如下:

[source]

  • notice.txt
  • reference -> 从 Asciidoc 生成的参考文档
    • html
    • pdf
    • epub
  • api -> JavaDoc

生成第二个 ZIP 文件,上传到 docs.spring.io,包含所有 Spring 命名空间 XSD。

预配置了以下依赖项:

  • 日志依赖:SLF4j + Commons Logging 桥接器和 Logback 作为测试依赖
  • 测试依赖:JUnit / AssertJ / Hamcrest / Mockito
  • 常用依赖项的版本

=== 单项目设置

如果客户端项目只包含一个项目,只需声明父项目即可:

[source,xml]

org.springframework.data.build spring-data-parent ${most-recent-release-version} ----

请确保将版本号调整为最新的发布版本。设置的第二个也是最后一步是在构建部分激活程序集和 asciidoctor 插件:

[source,xml]

org.apache.maven.plugins maven-assembly-plugin org.asciidoctor asciidoctor-maven-plugin ----

https://github.com/spring-projects/spring-data-jpa[Spring Data JPA] 的构建为例。

=== 多项目设置

多模块设置需要更多配置和一些结构设置。

  • pom.xml 需要将 project.type 属性配置为 multi
  • Asciidoc 文档源文件需要放在根项目中。
  • 程序集需要在专用子模块(如 distribution)中构建,在该子模块中声明程序集插件(参见单项目设置),并在该模块中将 project.root 属性重新配置为 ${basedir}/..
  • 在根项目中将 ${dist.id} 配置为基本工件 ID(如 spring-data-mongodb),因为它将作为分发工件、静态资源等的文件名。如果未正确配置,它将默认为工件 ID,通常解析为 ...-parent

https://github.com/spring-projects/spring-data-mongodb[Spring Data MongoDB] 的构建为例。

== 构建配置

  • 执行 clean (dependency:tree) install -Pci 目标以运行构建
  • 执行 clean deploy -Pci,artifactory 目标以将工件部署到 Artifactory
  • 夜间构建可以使用 clean (dependency:tree) deploy -Pdistribute 来发布参考文档

== 附加构建配置文件

  • ci - 将 JavaDoc 打包为 JAR 以进行分发(需要在 CI 服务器上激活,以确保我们将 JavaDoc 作为 JAR 分发)。
  • distribute - 创建 Asciidoc 文档。
  • distribute-schema - 创建模式文件分发。
  • spring...-next - 将要使用的 Spring 版本配置为下一个 Spring Framework 快照版本。

== 许可证

Spring Data Build 是根据 https://www.apache.org/licenses/LICENSE-2.0.html[Apache 2.0 许可证] 发布的开源软件。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号