Skip to content

Commit 11f66fb

Browse files
committed
initial commit
0 parents  commit 11f66fb

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

51 files changed

+1223
-0
lines changed

.Rbuildignore

+5
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
^LICENSE\.md$
2+
^.*\.Rproj$
3+
^\.Rproj\.user$
4+
^\.github$
5+
^\.conbench$

.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
.conbench

DESCRIPTION

+31
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
Package: conbenchcoms
2+
Title: An API wrapper for conbench communications
3+
Version: 0.0.1
4+
Authors@R: c(
5+
person("Jonathan", "Keane", , "[email protected]", role = c("aut", "cre"),
6+
comment = c(ORCID = "0000-0001-7087-9776")),
7+
person("Sam", "Albers", , "[email protected]", role = c("aut", "ctb"),
8+
comment = c(ORCID = "0000-0002-9270-7884")),
9+
person("Edward", "Visel", , "[email protected]", role = c("aut", "ctb"),
10+
comment = c(ORCID = "0000-0002-2811-6254")),
11+
person(given = "Voltron Data",
12+
role = c("cph", "fnd"))
13+
)
14+
Description: An R interface to the conbench API.
15+
License: Apache License (>= 2)
16+
Depends:
17+
R (>= 4.1.0)
18+
Imports:
19+
curl,
20+
glue,
21+
httr2,
22+
utils,
23+
yaml
24+
Suggests:
25+
httptest2,
26+
testthat (>= 3.0.0),
27+
withr
28+
Config/testthat/edition: 3
29+
Encoding: UTF-8
30+
Roxygen: list(markdown = TRUE)
31+
RoxygenNote: 7.2.1

LICENSE.md

+194
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,194 @@
1+
Apache License
2+
==============
3+
4+
_Version 2.0, January 2004_
5+
_&lt;<http://www.apache.org/licenses/>&gt;_
6+
7+
### Terms and Conditions for use, reproduction, and distribution
8+
9+
#### 1. Definitions
10+
11+
“License” shall mean the terms and conditions for use, reproduction, and
12+
distribution as defined by Sections 1 through 9 of this document.
13+
14+
“Licensor” shall mean the copyright owner or entity authorized by the copyright
15+
owner that is granting the License.
16+
17+
“Legal Entity” shall mean the union of the acting entity and all other entities
18+
that control, are controlled by, or are under common control with that entity.
19+
For the purposes of this definition, “control” means **(i)** the power, direct or
20+
indirect, to cause the direction or management of such entity, whether by
21+
contract or otherwise, or **(ii)** ownership of fifty percent (50%) or more of the
22+
outstanding shares, or **(iii)** beneficial ownership of such entity.
23+
24+
“You” (or “Your”) shall mean an individual or Legal Entity exercising
25+
permissions granted by this License.
26+
27+
“Source” form shall mean the preferred form for making modifications, including
28+
but not limited to software source code, documentation source, and configuration
29+
files.
30+
31+
“Object” form shall mean any form resulting from mechanical transformation or
32+
translation of a Source form, including but not limited to compiled object code,
33+
generated documentation, and conversions to other media types.
34+
35+
“Work” shall mean the work of authorship, whether in Source or Object form, made
36+
available under the License, as indicated by a copyright notice that is included
37+
in or attached to the work (an example is provided in the Appendix below).
38+
39+
“Derivative Works” shall mean any work, whether in Source or Object form, that
40+
is based on (or derived from) the Work and for which the editorial revisions,
41+
annotations, elaborations, or other modifications represent, as a whole, an
42+
original work of authorship. For the purposes of this License, Derivative Works
43+
shall not include works that remain separable from, or merely link (or bind by
44+
name) to the interfaces of, the Work and Derivative Works thereof.
45+
46+
“Contribution” shall mean any work of authorship, including the original version
47+
of the Work and any modifications or additions to that Work or Derivative Works
48+
thereof, that is intentionally submitted to Licensor for inclusion in the Work
49+
by the copyright owner or by an individual or Legal Entity authorized to submit
50+
on behalf of the copyright owner. For the purposes of this definition,
51+
“submitted” means any form of electronic, verbal, or written communication sent
52+
to the Licensor or its representatives, including but not limited to
53+
communication on electronic mailing lists, source code control systems, and
54+
issue tracking systems that are managed by, or on behalf of, the Licensor for
55+
the purpose of discussing and improving the Work, but excluding communication
56+
that is conspicuously marked or otherwise designated in writing by the copyright
57+
owner as “Not a Contribution.”
58+
59+
“Contributor” shall mean Licensor and any individual or Legal Entity on behalf
60+
of whom a Contribution has been received by Licensor and subsequently
61+
incorporated within the Work.
62+
63+
#### 2. Grant of Copyright License
64+
65+
Subject to the terms and conditions of this License, each Contributor hereby
66+
grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
67+
irrevocable copyright license to reproduce, prepare Derivative Works of,
68+
publicly display, publicly perform, sublicense, and distribute the Work and such
69+
Derivative Works in Source or Object form.
70+
71+
#### 3. Grant of Patent License
72+
73+
Subject to the terms and conditions of this License, each Contributor hereby
74+
grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
75+
irrevocable (except as stated in this section) patent license to make, have
76+
made, use, offer to sell, sell, import, and otherwise transfer the Work, where
77+
such license applies only to those patent claims licensable by such Contributor
78+
that are necessarily infringed by their Contribution(s) alone or by combination
79+
of their Contribution(s) with the Work to which such Contribution(s) was
80+
submitted. If You institute patent litigation against any entity (including a
81+
cross-claim or counterclaim in a lawsuit) alleging that the Work or a
82+
Contribution incorporated within the Work constitutes direct or contributory
83+
patent infringement, then any patent licenses granted to You under this License
84+
for that Work shall terminate as of the date such litigation is filed.
85+
86+
#### 4. Redistribution
87+
88+
You may reproduce and distribute copies of the Work or Derivative Works thereof
89+
in any medium, with or without modifications, and in Source or Object form,
90+
provided that You meet the following conditions:
91+
92+
* **(a)** You must give any other recipients of the Work or Derivative Works a copy of
93+
this License; and
94+
* **(b)** You must cause any modified files to carry prominent notices stating that You
95+
changed the files; and
96+
* **(c)** You must retain, in the Source form of any Derivative Works that You distribute,
97+
all copyright, patent, trademark, and attribution notices from the Source form
98+
of the Work, excluding those notices that do not pertain to any part of the
99+
Derivative Works; and
100+
* **(d)** If the Work includes a “NOTICE” text file as part of its distribution, then any
101+
Derivative Works that You distribute must include a readable copy of the
102+
attribution notices contained within such NOTICE file, excluding those notices
103+
that do not pertain to any part of the Derivative Works, in at least one of the
104+
following places: within a NOTICE text file distributed as part of the
105+
Derivative Works; within the Source form or documentation, if provided along
106+
with the Derivative Works; or, within a display generated by the Derivative
107+
Works, if and wherever such third-party notices normally appear. The contents of
108+
the NOTICE file are for informational purposes only and do not modify the
109+
License. You may add Your own attribution notices within Derivative Works that
110+
You distribute, alongside or as an addendum to the NOTICE text from the Work,
111+
provided that such additional attribution notices cannot be construed as
112+
modifying the License.
113+
114+
You may add Your own copyright statement to Your modifications and may provide
115+
additional or different license terms and conditions for use, reproduction, or
116+
distribution of Your modifications, or for any such Derivative Works as a whole,
117+
provided Your use, reproduction, and distribution of the Work otherwise complies
118+
with the conditions stated in this License.
119+
120+
#### 5. Submission of Contributions
121+
122+
Unless You explicitly state otherwise, any Contribution intentionally submitted
123+
for inclusion in the Work by You to the Licensor shall be under the terms and
124+
conditions of this License, without any additional terms or conditions.
125+
Notwithstanding the above, nothing herein shall supersede or modify the terms of
126+
any separate license agreement you may have executed with Licensor regarding
127+
such Contributions.
128+
129+
#### 6. Trademarks
130+
131+
This License does not grant permission to use the trade names, trademarks,
132+
service marks, or product names of the Licensor, except as required for
133+
reasonable and customary use in describing the origin of the Work and
134+
reproducing the content of the NOTICE file.
135+
136+
#### 7. Disclaimer of Warranty
137+
138+
Unless required by applicable law or agreed to in writing, Licensor provides the
139+
Work (and each Contributor provides its Contributions) on an “AS IS” BASIS,
140+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied,
141+
including, without limitation, any warranties or conditions of TITLE,
142+
NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are
143+
solely responsible for determining the appropriateness of using or
144+
redistributing the Work and assume any risks associated with Your exercise of
145+
permissions under this License.
146+
147+
#### 8. Limitation of Liability
148+
149+
In no event and under no legal theory, whether in tort (including negligence),
150+
contract, or otherwise, unless required by applicable law (such as deliberate
151+
and grossly negligent acts) or agreed to in writing, shall any Contributor be
152+
liable to You for damages, including any direct, indirect, special, incidental,
153+
or consequential damages of any character arising as a result of this License or
154+
out of the use or inability to use the Work (including but not limited to
155+
damages for loss of goodwill, work stoppage, computer failure or malfunction, or
156+
any and all other commercial damages or losses), even if such Contributor has
157+
been advised of the possibility of such damages.
158+
159+
#### 9. Accepting Warranty or Additional Liability
160+
161+
While redistributing the Work or Derivative Works thereof, You may choose to
162+
offer, and charge a fee for, acceptance of support, warranty, indemnity, or
163+
other liability obligations and/or rights consistent with this License. However,
164+
in accepting such obligations, You may act only on Your own behalf and on Your
165+
sole responsibility, not on behalf of any other Contributor, and only if You
166+
agree to indemnify, defend, and hold each Contributor harmless for any liability
167+
incurred by, or claims asserted against, such Contributor by reason of your
168+
accepting any such warranty or additional liability.
169+
170+
_END OF TERMS AND CONDITIONS_
171+
172+
### APPENDIX: How to apply the Apache License to your work
173+
174+
To apply the Apache License to your work, attach the following boilerplate
175+
notice, with the fields enclosed by brackets `[]` replaced with your own
176+
identifying information. (Don't include the brackets!) The text should be
177+
enclosed in the appropriate comment syntax for the file format. We also
178+
recommend that a file or class name and description of purpose be included on
179+
the same “printed page” as the copyright notice for easier identification within
180+
third-party archives.
181+
182+
Copyright [yyyy] [name of copyright owner]
183+
184+
Licensed under the Apache License, Version 2.0 (the "License");
185+
you may not use this file except in compliance with the License.
186+
You may obtain a copy of the License at
187+
188+
http://www.apache.org/licenses/LICENSE-2.0
189+
190+
Unless required by applicable law or agreed to in writing, software
191+
distributed under the License is distributed on an "AS IS" BASIS,
192+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
193+
See the License for the specific language governing permissions and
194+
limitations under the License.

NAMESPACE

+12
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
# Generated by roxygen2: do not edit by hand
2+
3+
export(benchmarks)
4+
export(compare)
5+
export(conbench_perform)
6+
export(conbench_request)
7+
export(hardware)
8+
export(history)
9+
export(info)
10+
export(runs)
11+
export(url_cleaner)
12+
import(httr2)

R/benchmarks.R

+28
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
#' Get a list of benchmarks
2+
#'
3+
#' @param run_id the run_id to get benchmarks for (default: `NULL`, list all)
4+
#' @param batch_id the batch_id to get benchmarks for (default: `NULL`, list all)
5+
#' @inheritParams runs
6+
#'
7+
#' @return the response
8+
#' @export
9+
benchmarks <- function(run_id = NULL, batch_id = NULL, simplifyVector = TRUE, flatten = TRUE, ...) {
10+
req <- req_url_path_append(conbench_request(), "benchmarks")
11+
12+
if (!is.null(batch_id)) {
13+
req <- req_url_query(req, batch_id = paste0(batch_id, collapse = ","))
14+
if (!utils::packageVersion("httr2") > "0.2.1") {
15+
req$url <- curl::curl_unescape(req$url)
16+
}
17+
}
18+
19+
if (!is.null(run_id)) {
20+
req <- req_url_query(req, run_id = paste0(run_id, collapse = ","))
21+
if (!utils::packageVersion("httr2") > "0.2.1") {
22+
req$url <- curl::curl_unescape(req$url)
23+
}
24+
}
25+
resp <- conbench_perform(req)
26+
27+
resp_body_json(resp, simplifyVector = simplifyVector, flatten = flatten, ...)
28+
}

R/compare.R

+25
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
#' Compare runs, benchmarks, batches, or commits
2+
#'
3+
#' @param type the type of comparison to make (one of: runs, benchmarks, batches, commits)
4+
#' @param baseline the baseline sha of the entity to compare
5+
#' @param contender the contender sha of the entity to compare
6+
#' @inheritDotParams httr2::resp_body_json
7+
#'
8+
#' @return the JSON response
9+
#' @export
10+
compare <- function(type = c("runs", "benchmarks", "batches", "commits"),
11+
baseline,
12+
contender,
13+
...) {
14+
type <- match.arg(type)
15+
16+
req <- req_url_path_append(
17+
conbench_request(),
18+
"compare",
19+
type,
20+
paste0(baseline, "...", contender))
21+
22+
resp <- conbench_perform(req)
23+
24+
resp_body_json(resp, ...)
25+
}

R/conbench-request.R

+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
#' A wrapper around `request()` with Conbench URL
2+
#'
3+
#' Takes all the same arguments as `request()`. Should be used at the beginning
4+
#' of an `httr2` pipeline. By default, the conbench URL will be read from the
5+
#' .conbench file in the current working directory.
6+
#'
7+
#' @param base_url the base URL to use
8+
#'
9+
#' @return the request
10+
#' @export
11+
conbench_request <- function(base_url = NULL) {
12+
if (is.null(base_url)) {
13+
base_url <- tryCatch(
14+
get_config()$url,
15+
error = function(e) "https://conbench.ursa.dev"
16+
)
17+
18+
base_url <- paste0(base_url, "/api")
19+
}
20+
21+
request(base_url)
22+
}

R/conbenchcoms-package.R

+11
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
#' @keywords internal
2+
"_PACKAGE"
3+
4+
# The following block is used by usethis to automatically manage
5+
# roxygen namespace tags. Modify with care!
6+
## usethis namespace: start
7+
## usethis namespace: end
8+
NULL
9+
10+
#' @import httr2
11+
NULL

R/hardware.R

+18
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
#' Get hardware
2+
#'
3+
#' @param id the id of one specific hardware to get data for.
4+
#' @inheritParams runs
5+
#'
6+
#' @return the response
7+
#' @export
8+
hardware <- function(id = NULL, simplifyVector = TRUE, flatten = TRUE, ...) {
9+
req <- req_url_path_append(conbench_request(), "hardware")
10+
11+
if (!is.null(id)) {
12+
req <- req_url_path_append(req, id)
13+
}
14+
15+
resp <- conbench_perform(req)
16+
17+
resp_body_json(resp, simplifyVector = simplifyVector, flatten = flatten, ...)
18+
}

R/history.R

+14
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
#' Get history for a benchmark
2+
#'
3+
#' @param benchmark_id the hash of a benchmark to get the history for
4+
#' @inheritParams runs
5+
#'
6+
#' @return the response
7+
#' @export
8+
history <- function(benchmark_id, simplifyVector = TRUE, flatten = TRUE, ...) {
9+
req <- req_url_path_append(conbench_request(), "history", benchmark_id)
10+
11+
resp <- conbench_perform(req)
12+
13+
resp_body_json(resp, simplifyVector = simplifyVector, flatten = flatten, ...)
14+
}

R/info.R

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
#' Get a list of benchmark info
2+
#'
3+
#' @param id the info id for benchmark info
4+
#' @inheritParams runs
5+
#'
6+
#' @return the response
7+
#' @export
8+
9+
info <- function(id = NULL, simplifyVector = TRUE, flatten = TRUE, ...) {
10+
req <- req_url_path_append(conbench_request(), "info")
11+
12+
if (!is.null(id)) {
13+
req <- req_url_path_append(req, id)
14+
}
15+
16+
resp <- conbench_perform(req)
17+
18+
resp_body_json(resp, simplifyVector = simplifyVector, flatten = flatten, ...)
19+
}
20+
21+

0 commit comments

Comments
 (0)