Compare commits

...

11 commits

Author SHA1 Message Date
Pierre Cavin
75d540fc57
Merge 6f7cbc459f into b7f96b2ea1 2025-01-01 14:21:45 +00:00
renovate[bot]
b7f96b2ea1
build(deps): update aws-sdk-js-v3 monorepo (#33359)
Some checks are pending
Build / setup (push) Waiting to run
Build / setup-build (push) Waiting to run
Build / prefetch (push) Blocked by required conditions
Build / lint-eslint (push) Blocked by required conditions
Build / lint-prettier (push) Blocked by required conditions
Build / lint-docs (push) Blocked by required conditions
Build / lint-other (push) Blocked by required conditions
Build / (push) Blocked by required conditions
Build / codecov (push) Blocked by required conditions
Build / coverage-threshold (push) Blocked by required conditions
Build / test-success (push) Blocked by required conditions
Build / build (push) Blocked by required conditions
Build / build-docs (push) Blocked by required conditions
Build / test-e2e (push) Blocked by required conditions
Build / release (push) Blocked by required conditions
Code scanning / CodeQL-Build (push) Waiting to run
Scorecard supply-chain security / Scorecard analysis (push) Waiting to run
whitesource-scan / WS_SCAN (push) Waiting to run
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2025-01-01 00:40:40 +00:00
Pierre Cavin
6f7cbc459f
refactor: use regEx helper
Co-authored-by: Michael Kriese <michael.kriese@gmx.de>
2024-12-30 12:38:31 +01:00
Pierre Cavin
a20f8d753a
docs(mix): remove superfluous information & add link to Elixir SemVer 2024-12-28 15:34:43 +01:00
Pierre Cavin
3275794ff4
docs(mix): improve style consistency 2024-12-28 11:58:55 +01:00
Pierre Cavin
9a12b77c0c
fix(mix): rename depTypes to prod & dev 2024-12-28 11:56:41 +01:00
Pierre Cavin
601b6ac2ac
style: run prettier fix 2024-12-28 03:24:53 +01:00
Pierre Cavin
2d1fdacf22
test: add more edge cases 2024-12-27 22:31:53 +01:00
Pierre Cavin
4852ad562e
feat(mix): implement depType parsing 2024-12-27 22:26:31 +01:00
Pierre Cavin
20cdf5d088
test: tdd be like 2024-12-27 21:06:26 +01:00
Pierre Cavin
7bc32fa322
test(fixtures): add credo & add smoke test 2024-12-27 20:43:58 +01:00
7 changed files with 447 additions and 359 deletions

View file

@ -27,13 +27,19 @@ defmodule MyProject.MixProject do
{:secret, "~> 1.0", organization: "acme"}, {:secret, "~> 1.0", organization: "acme"},
{:also_secret, "~> 1.0", only: [:dev, :test], organization: "acme", runtime: false}, {:also_secret, "~> 1.0", only: [:dev, :test], organization: "acme", runtime: false},
{:metrics, ">0.2.0 and <=1.0.0"}, {:metrics, ">0.2.0 and <=1.0.0"},
{:jason, ">= 1.0.0"}, {:jason, ">= 1.0.0", only: :prod},
{:hackney, "~> 1.0", {:hackney, "~> 1.0",
optional: true}, optional: true},
{:hammer_backend_redis, "~> 6.1"}, {:hammer_backend_redis, "~> 6.1", only: [:dev, :prod, :test]},
{:castore, "== 1.0.10"}, {:castore, "== 1.0.10"},
{:gun, "~> 2.0.0", hex: "grpc_gun"}, {:gun, "~> 2.0.0", hex: "grpc_gun"},
{:another_gun, "~> 0.4.0", hex: :raygun}, {:another_gun, "~> 0.4.0", hex: :raygun},
{:credo, "~> 1.7", only:
[:test,
# prod,
:dev],
runtime: false},
{:floki, "== 0.37.0", only: :test},
] ]
end end
end end

View file

@ -1,13 +1,17 @@
%{ %{
"another_gun": {:hex, :raygun, "0.4.0", "7744e99dd695f61e78ad5e047cce0affb3edfc6f93a92278598ab553b9c5091f", [:mix], [{:httpoison, "~> 0.8 or ~> 1.0", [hex: :httpoison, repo: "hexpm", optional: false]}, {:jason, "~> 1.2", [hex: :jason, repo: "hexpm", optional: false]}, {:plug, "~> 1.1", [hex: :plug, repo: "hexpm", optional: false]}], "hexpm", "eee4b891e6e65c6a4b15386dc7b7a72b717f3c123cc0012cfd19e8f2ab21116d"}, "another_gun": {:hex, :raygun, "0.4.0", "7744e99dd695f61e78ad5e047cce0affb3edfc6f93a92278598ab553b9c5091f", [:mix], [{:httpoison, "~> 0.8 or ~> 1.0", [hex: :httpoison, repo: "hexpm", optional: false]}, {:jason, "~> 1.2", [hex: :jason, repo: "hexpm", optional: false]}, {:plug, "~> 1.1", [hex: :plug, repo: "hexpm", optional: false]}], "hexpm", "eee4b891e6e65c6a4b15386dc7b7a72b717f3c123cc0012cfd19e8f2ab21116d"},
"bunt": {:hex, :bunt, "1.0.0", "081c2c665f086849e6d57900292b3a161727ab40431219529f13c4ddcf3e7a44", [:mix], [], "hexpm", "dc5f86aa08a5f6fa6b8096f0735c4e76d54ae5c9fa2c143e5a1fc7c1cd9bb6b5"},
"castore": {:hex, :castore, "1.0.10", "43bbeeac820f16c89f79721af1b3e092399b3a1ecc8df1a472738fd853574911", [:mix], [], "hexpm", "1b0b7ea14d889d9ea21202c43a4fa015eb913021cb535e8ed91946f4b77a8848"}, "castore": {:hex, :castore, "1.0.10", "43bbeeac820f16c89f79721af1b3e092399b3a1ecc8df1a472738fd853574911", [:mix], [], "hexpm", "1b0b7ea14d889d9ea21202c43a4fa015eb913021cb535e8ed91946f4b77a8848"},
"certifi": {:hex, :certifi, "2.12.0", "2d1cca2ec95f59643862af91f001478c9863c2ac9cb6e2f89780bfd8de987329", [:rebar3], [], "hexpm", "ee68d85df22e554040cdb4be100f33873ac6051387baf6a8f6ce82272340ff1c"}, "certifi": {:hex, :certifi, "2.12.0", "2d1cca2ec95f59643862af91f001478c9863c2ac9cb6e2f89780bfd8de987329", [:rebar3], [], "hexpm", "ee68d85df22e554040cdb4be100f33873ac6051387baf6a8f6ce82272340ff1c"},
"cowboy": {:git, "https://github.com/ninenines/cowboy.git", "0c2e2224e372f01e6cf51a8e12d4856edb4cb8ac", [tag: "0.6.0"]}, "cowboy": {:git, "https://github.com/ninenines/cowboy.git", "0c2e2224e372f01e6cf51a8e12d4856edb4cb8ac", [tag: "0.6.0"]},
"cowlib": {:hex, :cowlib, "2.13.0", "db8f7505d8332d98ef50a3ef34b34c1afddec7506e4ee4dd4a3a266285d282ca", [:make, :rebar3], [], "hexpm", "e1e1284dc3fc030a64b1ad0d8382ae7e99da46c3246b815318a4b848873800a4"}, "cowlib": {:hex, :cowlib, "2.13.0", "db8f7505d8332d98ef50a3ef34b34c1afddec7506e4ee4dd4a3a266285d282ca", [:make, :rebar3], [], "hexpm", "e1e1284dc3fc030a64b1ad0d8382ae7e99da46c3246b815318a4b848873800a4"},
"credo": {:hex, :credo, "1.7.10", "6e64fe59be8da5e30a1b96273b247b5cf1cc9e336b5fd66302a64b25749ad44d", [:mix], [{:bunt, "~> 0.2.1 or ~> 1.0", [hex: :bunt, repo: "hexpm", optional: false]}, {:file_system, "~> 0.2 or ~> 1.0", [hex: :file_system, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: false]}], "hexpm", "71fbc9a6b8be21d993deca85bf151df023a3097b01e09a2809d460348561d8cd"},
"decimal": {:hex, :decimal, "1.9.0", "83e8daf59631d632b171faabafb4a9f4242c514b0a06ba3df493951c08f64d07", [:mix], [], "hexpm", "b1f2343568eed6928f3e751cf2dffde95bfaa19dd95d09e8a9ea92ccfd6f7d85"}, "decimal": {:hex, :decimal, "1.9.0", "83e8daf59631d632b171faabafb4a9f4242c514b0a06ba3df493951c08f64d07", [:mix], [], "hexpm", "b1f2343568eed6928f3e751cf2dffde95bfaa19dd95d09e8a9ea92ccfd6f7d85"},
"ecto": {:git, "https://github.com/elixir-ecto/ecto.git", "795036d997c7503b21fb64d6bf1a89b83c44f2b5", [ref: "795036d997c7503b21fb64d6bf1a89b83c44f2b5"]}, "ecto": {:git, "https://github.com/elixir-ecto/ecto.git", "795036d997c7503b21fb64d6bf1a89b83c44f2b5", [ref: "795036d997c7503b21fb64d6bf1a89b83c44f2b5"]},
"secret": {:hex, :secret, "1.5.0", "344dbbf6610d205760ec37e2848bff2aab5a2de182bb5cdaa72cc2fd19d74535", [:mix], [{:decimal, "~> 1.0", [hex: :decimal, repo: "hexpm", optional: false]}], "hexpm", "19c205c8de0e2e5817f2250100281c58e717cb11ff1bb410bf661ee78c24e79b"}, "secret": {:hex, :secret, "1.5.0", "344dbbf6610d205760ec37e2848bff2aab5a2de182bb5cdaa72cc2fd19d74535", [:mix], [{:decimal, "~> 1.0", [hex: :decimal, repo: "hexpm", optional: false]}], "hexpm", "19c205c8de0e2e5817f2250100281c58e717cb11ff1bb410bf661ee78c24e79b"},
"also_secret": {:hex, :also_secret, "1.3.4", "344dbbf6610d205760ec37e2848bff2aab5a2de182bb5cdaa72cc2fd19d74535", [:mix], [{:decimal, "~> 1.0", [hex: :decimal, repo: "hexpm", optional: false]}], "hexpm", "19c205c8de0e2e5817f2250100281c58e717cb11ff1bb410bf661ee78c24e79b"}, "also_secret": {:hex, :also_secret, "1.3.4", "344dbbf6610d205760ec37e2848bff2aab5a2de182bb5cdaa72cc2fd19d74535", [:mix], [{:decimal, "~> 1.0", [hex: :decimal, repo: "hexpm", optional: false]}], "hexpm", "19c205c8de0e2e5817f2250100281c58e717cb11ff1bb410bf661ee78c24e79b"},
"file_system": {:hex, :file_system, "1.0.1", "79e8ceaddb0416f8b8cd02a0127bdbababe7bf4a23d2a395b983c1f8b3f73edd", [:mix], [], "hexpm", "4414d1f38863ddf9120720cd976fce5bdde8e91d8283353f0e31850fa89feb9e"},
"floki": {:hex, :floki, "0.37.0", "b83e0280bbc6372f2a403b2848013650b16640cd2470aea6701f0632223d719e", [:mix], [], "hexpm", "516a0c15a69f78c47dc8e0b9b3724b29608aa6619379f91b1ffa47109b5d0dd3"},
"gun": {:hex, :grpc_gun, "2.0.1", "221b792df3a93e8fead96f697cbaf920120deacced85c6cd3329d2e67f0871f8", [:rebar3], [{:cowlib, "~> 2.11", [hex: :cowlib, repo: "hexpm", optional: false]}], "hexpm", "795a65eb9d0ba16697e6b0e1886009ce024799e43bb42753f0c59b029f592831"}, "gun": {:hex, :grpc_gun, "2.0.1", "221b792df3a93e8fead96f697cbaf920120deacced85c6cd3329d2e67f0871f8", [:rebar3], [{:cowlib, "~> 2.11", [hex: :cowlib, repo: "hexpm", optional: false]}], "hexpm", "795a65eb9d0ba16697e6b0e1886009ce024799e43bb42753f0c59b029f592831"},
"hackney": {:hex, :hackney, "1.20.1", "8d97aec62ddddd757d128bfd1df6c5861093419f8f7a4223823537bad5d064e2", [:rebar3], [{:certifi, "~> 2.12.0", [hex: :certifi, repo: "hexpm", optional: false]}, {:idna, "~> 6.1.0", [hex: :idna, repo: "hexpm", optional: false]}, {:metrics, "~> 1.0.0", [hex: :metrics, repo: "hexpm", optional: false]}, {:mimerl, "~> 1.1", [hex: :mimerl, repo: "hexpm", optional: false]}, {:parse_trans, "3.4.1", [hex: :parse_trans, repo: "hexpm", optional: false]}, {:ssl_verify_fun, "~> 1.1.0", [hex: :ssl_verify_fun, repo: "hexpm", optional: false]}, {:unicode_util_compat, "~> 0.7.0", [hex: :unicode_util_compat, repo: "hexpm", optional: false]}], "hexpm", "fe9094e5f1a2a2c0a7d10918fee36bfec0ec2a979994cff8cfe8058cd9af38e3"}, "hackney": {:hex, :hackney, "1.20.1", "8d97aec62ddddd757d128bfd1df6c5861093419f8f7a4223823537bad5d064e2", [:rebar3], [{:certifi, "~> 2.12.0", [hex: :certifi, repo: "hexpm", optional: false]}, {:idna, "~> 6.1.0", [hex: :idna, repo: "hexpm", optional: false]}, {:metrics, "~> 1.0.0", [hex: :metrics, repo: "hexpm", optional: false]}, {:mimerl, "~> 1.1", [hex: :mimerl, repo: "hexpm", optional: false]}, {:parse_trans, "3.4.1", [hex: :parse_trans, repo: "hexpm", optional: false]}, {:ssl_verify_fun, "~> 1.1.0", [hex: :ssl_verify_fun, repo: "hexpm", optional: false]}, {:unicode_util_compat, "~> 0.7.0", [hex: :unicode_util_compat, repo: "hexpm", optional: false]}], "hexpm", "fe9094e5f1a2a2c0a7d10918fee36bfec0ec2a979994cff8cfe8058cd9af38e3"},
"hammer": {:hex, :hammer, "6.2.1", "5ae9c33e3dceaeb42de0db46bf505bd9c35f259c8defb03390cd7556fea67ee2", [:mix], [{:poolboy, "~> 1.5", [hex: :poolboy, repo: "hexpm", optional: false]}], "hexpm", "b9476d0c13883d2dc0cc72e786bac6ac28911fba7cc2e04b70ce6a6d9c4b2bdc"}, "hammer": {:hex, :hammer, "6.2.1", "5ae9c33e3dceaeb42de0db46bf505bd9c35f259c8defb03390cd7556fea67ee2", [:mix], [{:poolboy, "~> 1.5", [hex: :poolboy, repo: "hexpm", optional: false]}], "hexpm", "b9476d0c13883d2dc0cc72e786bac6ac28911fba7cc2e04b70ce6a6d9c4b2bdc"},

View file

@ -20,12 +20,14 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 0.8.1', currentValue: '~> 0.8.1',
datasource: 'hex', datasource: 'hex',
depName: 'postgrex', depName: 'postgrex',
depType: 'prod',
packageName: 'postgrex', packageName: 'postgrex',
}, },
{ {
currentValue: '<1.7.0 or ~>1.7.1', currentValue: '<1.7.0 or ~>1.7.1',
datasource: 'hex', datasource: 'hex',
depName: 'ranch', depName: 'ranch',
depType: 'prod',
packageName: 'ranch', packageName: 'ranch',
}, },
{ {
@ -33,6 +35,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '0.6.0', currentValue: '0.6.0',
datasource: 'github-tags', datasource: 'github-tags',
depName: 'cowboy', depName: 'cowboy',
depType: 'prod',
packageName: 'ninenines/cowboy', packageName: 'ninenines/cowboy',
}, },
{ {
@ -40,6 +43,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: 'main', currentValue: 'main',
datasource: 'git-tags', datasource: 'git-tags',
depName: 'phoenix', depName: 'phoenix',
depType: 'prod',
packageName: 'https://github.com/phoenixframework/phoenix.git', packageName: 'https://github.com/phoenixframework/phoenix.git',
}, },
{ {
@ -47,42 +51,49 @@ describe('modules/manager/mix/extract', () => {
currentValue: undefined, currentValue: undefined,
datasource: 'github-tags', datasource: 'github-tags',
depName: 'ecto', depName: 'ecto',
depType: 'prod',
packageName: 'elixir-ecto/ecto', packageName: 'elixir-ecto/ecto',
}, },
{ {
currentValue: '~> 1.0', currentValue: '~> 1.0',
datasource: 'hex', datasource: 'hex',
depName: 'secret', depName: 'secret',
depType: 'prod',
packageName: 'secret:acme', packageName: 'secret:acme',
}, },
{ {
currentValue: '~> 1.0', currentValue: '~> 1.0',
datasource: 'hex', datasource: 'hex',
depName: 'also_secret', depName: 'also_secret',
depType: 'dev',
packageName: 'also_secret:acme', packageName: 'also_secret:acme',
}, },
{ {
currentValue: '>0.2.0 and <=1.0.0', currentValue: '>0.2.0 and <=1.0.0',
datasource: 'hex', datasource: 'hex',
depName: 'metrics', depName: 'metrics',
depType: 'prod',
packageName: 'metrics', packageName: 'metrics',
}, },
{ {
currentValue: '>= 1.0.0', currentValue: '>= 1.0.0',
datasource: 'hex', datasource: 'hex',
depName: 'jason', depName: 'jason',
depType: 'prod',
packageName: 'jason', packageName: 'jason',
}, },
{ {
currentValue: '~> 1.0', currentValue: '~> 1.0',
datasource: 'hex', datasource: 'hex',
depName: 'hackney', depName: 'hackney',
depType: 'prod',
packageName: 'hackney', packageName: 'hackney',
}, },
{ {
currentValue: '~> 6.1', currentValue: '~> 6.1',
datasource: 'hex', datasource: 'hex',
depName: 'hammer_backend_redis', depName: 'hammer_backend_redis',
depType: 'prod',
packageName: 'hammer_backend_redis', packageName: 'hammer_backend_redis',
}, },
{ {
@ -90,20 +101,38 @@ describe('modules/manager/mix/extract', () => {
currentVersion: '1.0.10', currentVersion: '1.0.10',
datasource: 'hex', datasource: 'hex',
depName: 'castore', depName: 'castore',
depType: 'prod',
packageName: 'castore', packageName: 'castore',
}, },
{ {
currentValue: '~> 2.0.0', currentValue: '~> 2.0.0',
datasource: 'hex', datasource: 'hex',
depName: 'gun', depName: 'gun',
depType: 'prod',
packageName: 'grpc_gun', packageName: 'grpc_gun',
}, },
{ {
currentValue: '~> 0.4.0', currentValue: '~> 0.4.0',
datasource: 'hex', datasource: 'hex',
depName: 'another_gun', depName: 'another_gun',
depType: 'prod',
packageName: 'raygun', packageName: 'raygun',
}, },
{
currentValue: '~> 1.7',
datasource: 'hex',
depName: 'credo',
depType: 'dev',
packageName: 'credo',
},
{
currentValue: '== 0.37.0',
currentVersion: '0.37.0',
datasource: 'hex',
depName: 'floki',
depType: 'dev',
packageName: 'floki',
},
]); ]);
}); });
@ -116,6 +145,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 0.8.1', currentValue: '~> 0.8.1',
datasource: 'hex', datasource: 'hex',
depName: 'postgrex', depName: 'postgrex',
depType: 'prod',
packageName: 'postgrex', packageName: 'postgrex',
lockedVersion: '0.8.4', lockedVersion: '0.8.4',
}, },
@ -123,6 +153,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '<1.7.0 or ~>1.7.1', currentValue: '<1.7.0 or ~>1.7.1',
datasource: 'hex', datasource: 'hex',
depName: 'ranch', depName: 'ranch',
depType: 'prod',
packageName: 'ranch', packageName: 'ranch',
lockedVersion: '1.7.1', lockedVersion: '1.7.1',
}, },
@ -131,6 +162,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '0.6.0', currentValue: '0.6.0',
datasource: 'github-tags', datasource: 'github-tags',
depName: 'cowboy', depName: 'cowboy',
depType: 'prod',
packageName: 'ninenines/cowboy', packageName: 'ninenines/cowboy',
lockedVersion: '0.6.0', lockedVersion: '0.6.0',
}, },
@ -139,6 +171,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: 'main', currentValue: 'main',
datasource: 'git-tags', datasource: 'git-tags',
depName: 'phoenix', depName: 'phoenix',
depType: 'prod',
packageName: 'https://github.com/phoenixframework/phoenix.git', packageName: 'https://github.com/phoenixframework/phoenix.git',
lockedVersion: undefined, lockedVersion: undefined,
}, },
@ -147,6 +180,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: undefined, currentValue: undefined,
datasource: 'github-tags', datasource: 'github-tags',
depName: 'ecto', depName: 'ecto',
depType: 'prod',
packageName: 'elixir-ecto/ecto', packageName: 'elixir-ecto/ecto',
lockedVersion: undefined, lockedVersion: undefined,
}, },
@ -154,6 +188,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 1.0', currentValue: '~> 1.0',
datasource: 'hex', datasource: 'hex',
depName: 'secret', depName: 'secret',
depType: 'prod',
packageName: 'secret:acme', packageName: 'secret:acme',
lockedVersion: '1.5.0', lockedVersion: '1.5.0',
}, },
@ -161,6 +196,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 1.0', currentValue: '~> 1.0',
datasource: 'hex', datasource: 'hex',
depName: 'also_secret', depName: 'also_secret',
depType: 'dev',
packageName: 'also_secret:acme', packageName: 'also_secret:acme',
lockedVersion: '1.3.4', lockedVersion: '1.3.4',
}, },
@ -168,6 +204,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '>0.2.0 and <=1.0.0', currentValue: '>0.2.0 and <=1.0.0',
datasource: 'hex', datasource: 'hex',
depName: 'metrics', depName: 'metrics',
depType: 'prod',
packageName: 'metrics', packageName: 'metrics',
lockedVersion: '1.0.0', lockedVersion: '1.0.0',
}, },
@ -175,6 +212,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '>= 1.0.0', currentValue: '>= 1.0.0',
datasource: 'hex', datasource: 'hex',
depName: 'jason', depName: 'jason',
depType: 'prod',
packageName: 'jason', packageName: 'jason',
lockedVersion: '1.4.4', lockedVersion: '1.4.4',
}, },
@ -182,6 +220,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 1.0', currentValue: '~> 1.0',
datasource: 'hex', datasource: 'hex',
depName: 'hackney', depName: 'hackney',
depType: 'prod',
packageName: 'hackney', packageName: 'hackney',
lockedVersion: '1.20.1', lockedVersion: '1.20.1',
}, },
@ -189,6 +228,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 6.1', currentValue: '~> 6.1',
datasource: 'hex', datasource: 'hex',
depName: 'hammer_backend_redis', depName: 'hammer_backend_redis',
depType: 'prod',
packageName: 'hammer_backend_redis', packageName: 'hammer_backend_redis',
lockedVersion: '6.2.0', lockedVersion: '6.2.0',
}, },
@ -197,6 +237,7 @@ describe('modules/manager/mix/extract', () => {
currentVersion: '1.0.10', currentVersion: '1.0.10',
datasource: 'hex', datasource: 'hex',
depName: 'castore', depName: 'castore',
depType: 'prod',
packageName: 'castore', packageName: 'castore',
lockedVersion: '1.0.10', lockedVersion: '1.0.10',
}, },
@ -204,6 +245,7 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 2.0.0', currentValue: '~> 2.0.0',
datasource: 'hex', datasource: 'hex',
depName: 'gun', depName: 'gun',
depType: 'prod',
packageName: 'grpc_gun', packageName: 'grpc_gun',
lockedVersion: '2.0.1', lockedVersion: '2.0.1',
}, },
@ -211,9 +253,27 @@ describe('modules/manager/mix/extract', () => {
currentValue: '~> 0.4.0', currentValue: '~> 0.4.0',
datasource: 'hex', datasource: 'hex',
depName: 'another_gun', depName: 'another_gun',
depType: 'prod',
packageName: 'raygun', packageName: 'raygun',
lockedVersion: '0.4.0', lockedVersion: '0.4.0',
}, },
{
currentValue: '~> 1.7',
datasource: 'hex',
depName: 'credo',
depType: 'dev',
packageName: 'credo',
lockedVersion: '1.7.10',
},
{
currentValue: '== 0.37.0',
currentVersion: '0.37.0',
datasource: 'hex',
depName: 'floki',
depType: 'dev',
lockedVersion: '0.37.0',
packageName: 'floki',
},
]); ]);
}); });
}); });

View file

@ -20,6 +20,8 @@ const lockedVersionRegExp = regEx(
/^\s+"(?<app>\w+)".*?"(?<lockedVersion>\d+\.\d+\.\d+)"/, /^\s+"(?<app>\w+)".*?"(?<lockedVersion>\d+\.\d+\.\d+)"/,
); );
const hexRegexp = regEx(/hex:\s*(?:"(?<strValue>[^"]+)"|:(?<atomValue>\w+))/); const hexRegexp = regEx(/hex:\s*(?:"(?<strValue>[^"]+)"|:(?<atomValue>\w+))/);
const onlyValueRegexp = regEx(/only:\s*(?<only>\[[^\]]*\]|:\w+)/);
const onlyEnvironmentsRegexp = regEx(/:(\w+)/gm);
export async function extractPackageFile( export async function extractPackageFile(
content: string, content: string,
@ -48,22 +50,28 @@ export async function extractPackageFile(
const hexGroups = hexRegexp.exec(opts)?.groups; const hexGroups = hexRegexp.exec(opts)?.groups;
const hex = hexGroups?.strValue ?? hexGroups?.atomValue; const hex = hexGroups?.strValue ?? hexGroups?.atomValue;
let dep: PackageDependency; const onlyValue = onlyValueRegexp.exec(opts)?.groups?.only;
const onlyEnvironments = [];
let match;
if (onlyValue) {
while ((match = onlyEnvironmentsRegexp.exec(onlyValue)) !== null) {
onlyEnvironments.push(match[1]);
}
}
const dep: PackageDependency = {
depName: app,
depType: 'prod',
};
if (git ?? github) { if (git ?? github) {
dep = { dep.currentDigest = ref;
depName: app, dep.currentValue = branchOrTag;
currentDigest: ref, dep.datasource = git ? GitTagsDatasource.id : GithubTagsDatasource.id;
currentValue: branchOrTag, dep.packageName = git ?? github;
datasource: git ? GitTagsDatasource.id : GithubTagsDatasource.id,
packageName: git ?? github,
};
} else { } else {
dep = { dep.currentValue = requirement;
depName: app, dep.datasource = HexDatasource.id;
currentValue: requirement,
datasource: HexDatasource.id,
};
if (organization) { if (organization) {
dep.packageName = `${app}:${organization}`; dep.packageName = `${app}:${organization}`;
} else if (hex) { } else if (hex) {
@ -71,11 +79,16 @@ export async function extractPackageFile(
} else { } else {
dep.packageName = app; dep.packageName = app;
} }
if (requirement?.startsWith('==')) { if (requirement?.startsWith('==')) {
dep.currentVersion = requirement.replace(regEx(/^==\s*/), ''); dep.currentVersion = requirement.replace(regEx(/^==\s*/), '');
} }
} }
if (onlyValue !== undefined && !onlyEnvironments.includes('prod')) {
dep.depType = 'dev';
}
deps.set(app, dep); deps.set(app, dep);
logger.trace({ dep }, `setting ${app}`); logger.trace({ dep }, `setting ${app}`);
depMatchGroups = depMatchRegExp.exec(depBuffer)?.groups; depMatchGroups = depMatchRegExp.exec(depBuffer)?.groups;

View file

@ -1,3 +1,8 @@
The `mix` manager extracts dependencies for the `hex` datasource and uses Renovate's implementation of Hex SemVer to evaluate updates. The `mix` manager uses Renovate's implementation of [Elixir SemVer](https://hexdocs.pm/elixir/Version.html#module-requirements) to evaluate update ranges.
The `mix` package manager itself is also used to keep the lock file up-to-date. The `mix` package manager itself is used to keep the lock file up-to-date.
The following `depTypes` are currently supported by the `mix` manager :
- `prod`: all dependencies by default
- `dev`: dependencies with [`:only` option](https://hexdocs.pm/mix/Mix.Tasks.Deps.html#module-dependency-definition-options) not containing `:prod`

View file

@ -143,12 +143,12 @@
"pnpm": "9.15.1" "pnpm": "9.15.1"
}, },
"dependencies": { "dependencies": {
"@aws-sdk/client-codecommit": "3.699.0", "@aws-sdk/client-codecommit": "3.716.0",
"@aws-sdk/client-ec2": "3.701.0", "@aws-sdk/client-ec2": "3.716.0",
"@aws-sdk/client-ecr": "3.699.0", "@aws-sdk/client-ecr": "3.720.0",
"@aws-sdk/client-rds": "3.699.0", "@aws-sdk/client-rds": "3.719.1",
"@aws-sdk/client-s3": "3.701.0", "@aws-sdk/client-s3": "3.717.0",
"@aws-sdk/credential-providers": "3.699.0", "@aws-sdk/credential-providers": "3.716.0",
"@breejs/later": "4.2.0", "@breejs/later": "4.2.0",
"@cdktf/hcl2json": "0.20.10", "@cdktf/hcl2json": "0.20.10",
"@opentelemetry/api": "1.9.0", "@opentelemetry/api": "1.9.0",

File diff suppressed because it is too large Load diff