如何在不发布到Packagist的情况下,测试一个本地开发的composer包?

通过配置 path 仓库可本地测试 Composer 包。1. 确保包含 composer.json 并遵循标准结构;2. 在主项目中添加 type 为 path 的仓库并指定本地路径;3. 执行 require 命令安装,Composer 将链接或复制文件;4. 可选使用通配符批量引入多个本地包,提升开发效率。

如何在不发布到packagist的情况下,测试一个本地开发的composer包?

在不发布到 Packagist 的情况下测试本地开发的 Composer 包,可以通过配置 path 资源(path repository) 实现。这样能让主项目引用本地包文件夹,像使用正式包一样进行依赖管理,无需上传到任何仓库。

1. 准备本地包结构

确保你的包遵循标准的 Composer 包结构,并包含 composer.json 文件。例如:

my-awesome-package/
├── src/
│ └── SomeClass.php
├── composer.json

其中 composer.json 至少要有名称和自动加载配置:

{
"name": "vendor/my-awesome-package",
"autoload": {
"psr-4": { "Vendor\MyAwesomePackage\": "src/" }
}
}

2. 在主项目中添加 path 仓库

在使用该包的主项目的 composer.json 中添加一个 path 类型的仓库:

"repositories": [
{
"type": "path",
"url": "../my-awesome-package"
}
],
"require": {
"vendor/my-awesome-package": "*@dev"
}

注意:url 是相对于主项目 composer.json 的路径。如果包在同级目录下,如上所示;也可以使用绝对路径或通配符(见下文)。

3. 安装并验证

运行以下命令安装本地包:

Blogcast™ Blogcast™

BlogcastTM是一个文本转语音的工具,允许用户创建播客、视频、电子学习课程的音频和音频书籍,而无需录制。

Blogcast™ 63 查看详情 Blogcast™ composer require vendor/my-awesome-package:@dev

Composer 会创建一个符号链接(Linux/macOS)或复制文件(Windows),将本地包引入 vendor/ 目录。你在本地修改代码后,主项目能立即生效(需重新加载自动加载器)。

4. 可选:使用通配符简化多包管理

如果你有多个本地包,可以用通配符方式一次性引入:

"repositories": [
{
"type": "path",
"url": "../packages/*"
}
]

这样所有在 ../packages/ 下的包都会被识别,只要它们的 name 和目录匹配。

基本上就这些。通过 path 仓库机制,你可以高效地迭代本地包,无需频繁提交、推送或发布版本。调试和集成变得非常直接。

以上就是如何在不发布到Packagist的情况下,测试一个本地开发的composer包?的详细内容,更多请关注php中文网其它相关文章!

本文转自网络,如有侵权请联系客服删除。