Skip to content

Commit

Permalink
ci/eval: add rebuildsByPlatform to the comparison result
Browse files Browse the repository at this point in the history
  • Loading branch information
GaetanLepage committed Dec 11, 2024
1 parent b343873 commit f65c8f7
Show file tree
Hide file tree
Showing 2 changed files with 92 additions and 30 deletions.
14 changes: 11 additions & 3 deletions ci/eval/compare/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ let
inherit (import ./utils.nix { inherit lib; })
diff
groupByKernel
convertToSystemPathAttrs
groupByPlatform
extractPackageNames
getLabels
uniqueStrings
Expand All @@ -25,16 +27,22 @@ let
changed-paths =
let
rebuilds = uniqueStrings (diffAttrs.added ++ diffAttrs.changed);
rebuildsAttrs = convertToSystemPathAttrs rebuilds;

rebuildsByKernel = groupByKernel rebuilds;
rebuildsByPlatform = groupByPlatform rebuildsAttrs;
rebuildsByKernel = groupByKernel rebuildsAttrs;
rebuildCountByKernel = lib.mapAttrs (
kernel: kernelRebuilds: lib.length kernelRebuilds
) rebuildsByKernel;
in
writeText "changed-paths.json" (
builtins.toJSON {
attrdiff = lib.mapAttrs (_: v: extractPackageNames v) diffAttrs;
inherit rebuildsByKernel rebuildCountByKernel;
attrdiff = lib.mapAttrs (_: extractPackageNames) diffAttrs;
inherit
rebuildsByPlatform
rebuildsByKernel
rebuildCountByKernel
;
labels = getLabels rebuildCountByKernel;
}
);
Expand Down
108 changes: 81 additions & 27 deletions ci/eval/compare/utils.nix
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,14 @@ rec {
# Borrowed from https://github.com/NixOS/nixpkgs/pull/355616
uniqueStrings = list: builtins.attrNames (builtins.groupBy lib.id list);

_processSystemPath =
# Turns
# "hello.aarch64-linux"
# into
# {
# name = "hello";
# system = "aarch64-linux";
# }
convertToSystemPathAttr =
packageSystemPath:
let
# python312Packages.torch.aarch64-linux -> ["python312Packages" "torch" "aarch64-linux"]
Expand All @@ -12,14 +19,43 @@ rec {

# ["python312Packages" "torch" "aarch64-linux"] -> ["python312Packages" "torch"]
packagePath = lib.sublist 0 (lib.length splittedPath - 1) splittedPath;
in
{

# "python312Packages.torch"
name = lib.concatStringsSep "." packagePath;
in
if name == "" then
null
else
{
inherit name;

# "aarch64-linux"
system = lib.last splittedPath;
};
# "aarch64-linux"
system = lib.last splittedPath;
};

# Turns
# [
# "hello.aarch64-linux"
# "hello.x86_64-linux"
# "hello.aarch64-darwin"
# "hello.x86_64-darwin"
# "bye.x86_64-darwin"
# "bye.aarch64-darwin"
# "release-checks" <- Will be dropped
# ]
#
# into
#
# [
# { name = "hello"; system = "aarch64-linux"; }
# { name = "hello"; system = "x86_64-linux"; }
# { name = "hello"; system = "aarch64-darwin"; }
# { name = "hello"; system = "x86_64-darwin"; }
# { name = "bye"; system = "aarch64-darwin"; }
# { name = "bye"; system = "x86_64-darwin"; }
# ]
convertToSystemPathAttrs =
systemPaths: builtins.filter (x: x != null) (builtins.map convertToSystemPathAttr systemPaths);

# Turns
# [
Expand All @@ -39,11 +75,10 @@ rec {
# ]
extractPackageNames =
packageSystemPaths:
builtins.attrNames (
builtins.removeAttrs (builtins.groupBy (
packageSystemPath: (_processSystemPath packageSystemPath).name
) packageSystemPaths) [ "" ]
);
let
systemPathAttrs = convertToSystemPathAttrs (uniqueStrings packageSystemPaths);
in
builtins.map (p: p.name) systemPathAttrs;

# Computes a diff between two attrs
# {
Expand Down Expand Up @@ -71,35 +106,54 @@ rec {

# Turns
# [
# "hello.aarch64-linux"
# "hello.x86_64-linux"
# "hello.aarch64-darwin"
# "hello.x86_64-darwin"
# "bye.x86_64-darwin"
# "bye.aarch64-darwin"
# { name = "hello"; system = "aarch64-linux"; }
# { name = "hello"; system = "x86_64-linux"; }
# { name = "hello"; system = "aarch64-darwin"; }
# { name = "hello"; system = "x86_64-darwin"; }
# { name = "bye"; system = "aarch64-darwin"; }
# { name = "bye"; system = "x86_64-darwin"; }
# ]
#
# into
#
# {
# linux = [
# "hello"
# ];
# darwin = [
# "hello"
# "bye"
# ];
# aarch64-linux = [ "hello" ];
# x86_64-linux = [ "hello" ];
# aarch64-darwin = [ "hello" "bye" ];
# x86_64-darwin = [ "hello" "bye" ];
# }
groupByKernel =
groupByPlatform =
systemPaths:
let
systemPaths' = builtins.map _processSystemPath systemPaths;
systemPathsByPlatform = builtins.groupBy (systemPath: systemPath.system) systemPaths;
extractPackageNames = map (systemPath: systemPath.name);
in
lib.mapAttrs (_: extractPackageNames) systemPathsByPlatform;

# Turns
# [
# { name = "hello"; system = "aarch64-linux"; }
# { name = "hello"; system = "x86_64-linux"; }
# { name = "hello"; system = "aarch64-darwin"; }
# { name = "hello"; system = "x86_64-darwin"; }
# { name = "bye"; system = "aarch64-darwin"; }
# { name = "bye"; system = "x86_64-darwin"; }
# ]
#
# into
#
# {
# linux = [ "hello" ];
# darwin = [ "hello" "bye" ];
# }
groupByKernel =
systemPaths:
let
filterKernel =
kernel:
builtins.attrNames (
builtins.groupBy (systemPath: systemPath.name) (
builtins.filter (systemPath: lib.hasSuffix kernel systemPath.system) systemPaths'
builtins.filter (systemPath: lib.hasSuffix kernel systemPath.system) systemPaths
)
);
in
Expand Down

0 comments on commit f65c8f7

Please sign in to comment.