-
list-banks
: useAccountingFormatter
class (#524) -
add-user
: make--username
and--bank
required arguments (#532) -
edit-user
: unify reset behavior,**kwargs
for editable fields (#535)
-
view-job-records
: add--bank
filter option (#533) -
doc: add example on configuring priorities for queues (#542)
- t: change which user is deleted from
association_table
(#528)
- ci(mergify): upgrade configuration to current format (#537)
-
view-user
: make "parsable" spelling consistent (#494) -
projects: fix unit tests for project subcommands,
--projects
reset capability (#495) -
plugin: add callback prefixes to exception messages (#499)
-
add-bank
: add a check when adding a root bank (#509) -
fetch-job-records: set
max_entries=0
(#516) -
view-user --parsable
: improve output formatting (#514) -
flux-account.py
: get rid of dictionary initialization (#512) -
__init__.py
: fix formatting of constants (#521) -
view_jobs()
: adjust helper function to actually return a string (#522)
-
command suite: add new
list-projects
command (#496) -
ci: add spellchecker to flux-accounting (#504)
-
python: add
AccountingFormatter
class, SQLite utility file (#520)
-
.gitignore
: add built docs, sharness test results (#511) -
t: skip t1011 if job-archive module not detected, add new tests for
fetch-job-records
(#518)
-
doc: add note about manually loading plugin (#500)
-
doc: add ReadTheDocs support for flux-accounting (#501)
-
guide: add note about configuring factor weights (#505)
-
doc: add "Database Administration" section, update README to point to docs site (#506)
-
doc: reorganize top-level site, add License and Support page (#510)
-
doc: add priority equation to accounting guide (#513)
-
JobRecord: remove
username
from__init__()
of JobRecord object (#489) -
job.state.inactive
: addreturn -1
to exception (#492)
-
plugin: add project validation/annotation (#443)
-
view-job-records
: add--project
filter option (#490)
-
plugin: move
flux_respond ()
to end of functions (#431) -
Makefile: remove left over compile instructions for
flux_account_shares
(#482) -
configure: add
jansson
as a dependency check (#484) -
doc: add example error message when creating DB after starting systemd service (#485)
-
plugin: add instance owner info to plugin (#477)
-
cmd: add
export-db
as aflux account
command (#486) -
cmd: add
pop-db
as aflux account
command (#487)
-
python: change function descriptions to follow docstring convention (#468)
-
python: convert more function descriptions to docstring format (#470)
-
src: remove
flux_account_shares.cpp
in favor of just using-t
option withview-bank
(#471) -
fetch-job-records
: add integrity check for records (#475)
bank_table
: add a newlist-banks
command (#473)
-
t: move python unit tests to
t/python/
directory (#462) -
python: clean job-archive interface code (#463)
-
conf.update
: add missing bracket in format string (#465)
- testsuite: fix on systems with flux-accounting already installed (#467)
-
inactive_cb ()
: remove unused iterator variables (#457) -
plugin: initialize factor weights on plugin load (#458)
-
job archive interface: clean up a couple helper functions (#460)
- database: add the ability to remove old records from
jobs
table (#459)
-
job-archive interface: wrap job usage updates into a single SQL transaction (#452)
-
database: update schema version (#453)
- plugin: add configurable priority factors via TOML
conf.update
(#295)
-
testsuite: change check for specific job states (#393)
-
testsuite: replace
flux job cancel
-->flux cancel
(#454)
- repo: add
pkg.m4
, checks for flux-core libs (#441)
-
flux-accounting: add a local job-archive (#357)
-
plugin: add
max_nodes
as an attribute per-association in plugin (#437) -
repo: create a
doc
folder, add flux-accounting guide (#446)
-
t: update description of sharness tests (#447)
-
testsuite: enable guest access to testexec (#449)
-
plugin: move flux-accounting-specific helper functions, remove unused ones (#427)
-
plugin: improve
add_missing_bank_info ()
(#430) -
plugin: change
projects
->assoc_projects
inrec_update_cb ()
(#438)
-
plugin: add support for updating the bank of a pending job (#429)
-
plugin: add project information to Association information in plugin (#434)
-
plugin.query
: add projects, def_project to the information returned (#435)
-
t: add
active
column, move sample payloads (#432) -
t1029: remove brackets from
grep
tests (#433)
-
plugin: improve callback for
job.validate
(#415) -
plugin: move helper functions for
plugin.query
callback (#417) -
plugin: move
split_string ()
out of plugin code (#418) -
plugin: improve callback for
job.new
(#421) -
plugin: improve
job.update/job.update...queue
callbacks (#423) -
plugin: improve
job.state.priority
callback (#425)
- plugin: add external
Association
class to be used in plugin (#412)
-
plugin: keep jobs in
PRIORITY
after reprioritization (#407) -
plugin: add callback specific for validating an updated queue (#399)
- feat: developer container environment (#398)
-
edit-user
: fix default values for optional args (#382) -
plugin: improve check of internal user/bank map in
job.validate
(#386) -
plugin: move queue priority assignment to
job.new
callback (#388) -
view-bank
: fix-t
option for a sub bank with users in it (#395)
-
plugin: record bank name to jobspec in PRIORITY event (#301)
-
plugin: add queue update validation (#389)
-
load content module in rc scripts (#383)
-
ci: remove
upload-tarball
step from workflow (#387) -
testsuite: allow sharness tests to be run by hand (#392)
-
.cpp
: addconfig.h
include to source code (#366) -
.cpp
: wrap"config.h"
, C headers inextern "C"
(#368) -
python: remove empty
quotechar
argument fromcsv.writer
object initialization (#372) -
python: rename
rows
variable to something more descriptive (#374) -
plugin: check for
FLUX_JOB_STATE_NEW
invalidate_cb ()
(#378)
-
build: add
make deb
target for test packaging (#363) -
t: reorganize
t1007-flux-account.t
into multiple sharness tests (#367) -
docker: transition
bionic
container tojammy
(#369) -
t: add valgrind folder to flux-accounting (#373)
-
ci: update github actions
main.yml
file (#375)
- database: update DB schema version (#361)
-
bank_table: add new job_usage column (#359)
-
view-bank
: improve-t
option (#359)
- t: add new Python test directory in
t/
(#358)
- plugin: improve handling of submitted jobs based on data presence in plugin (#347)
-
flux-accounting service: make certain commands accessible to all users (#330)
-
flux-accounting service: change BindTo to BindsTo (#341)
-
view-user
: improve formatting of output of command (#342) -
update-db
: fix SQLite statement when updating a table with no primary key (#343)
- replace
flux mini
usage (#344)
- flux-accounting service: change Requires to BindTo (#338)
-
bindings: raise error to caller (#327, #328, #329)
-
plugin: clear queues on flux-accounting DB update (#334)
- plugin: rework increment/decrement of running and active job counts for associations (#325)
-
edit-user
: make "userid" an editable field (#319) -
view-*
commands: raiseValueError
when item cannot be found in flux-accounting DB (#320) -
view-bank
: re-add-t
option to command (#322)
view-job-records
: fix arguments passed in viaflux-account-service.py
(#316)
-
Add new service for
flux account
commands (#308) -
Add systemd unit file for flux-accounting service (#315)
- Add ability to edit the parent bank of a bank (#299)
-
Do not assume queues default to stopped (#302)
-
Stop all queues with
--all
option (#303)
- Change
update-db
command to create temporary database in/tmp
instead of current working directory (#288)
-
Add additional exception messages to Python commands (#267)
-
Improve dependency message for running jobs limit (#269)
-
Clean up user subcommand functions (#271)
-
Clean up bank subcommand functions (#275)
-
Disable queue validation in multi-factor priority plugin on unknown queue, no configured "default" queue after flux-core queue changes (#281)
-
Change default values of "DNE" entry to allow multiple jobs to be submitted (#286)
-
Change install location of multi-factor priority plugin (#287)
-
Add database schema version to flux-accounting DB (#274)
-
Add automatic DB upgrade to
flux account-priority-update
command if flux-accounting database is out of date (#274)
- Add new
plugin.query
callback to multi-factor priority plugin which returns internal information about users and banks, active and running job counts, and any held jobs at the time of the query (#264)
- Fix
update-db
command to provide clearer exception messages when the command fails to update a flux-accounting database (#258)
- Add new tests for the
update-db
command for updating old versions of a flux-accounting database (#258)
-
Fix
update-db
command to account for deleted columns when updating a flux-accounting database (#252) -
Improve error message clarity from sqlite3.connect when running the
update-db
command (#248)
- Add ability to disable a user/bank combo in the multi-factor priority plugin that prevents a user from submitting and running jobs (#254)
- Disable requirement for a
default
queue (#237)
-
Add a new
max_nodes
column to theassociation_table
which represents the max number of nodes a user/bank combo can have across all of their running jobs (#235) -
Add a sharness test for calculating job priorities of multiple users with different
--urgency
values (#236) -
Add a new
export-db
command which extracts information from both theassociation_table
andbank_table
into.csv
files for processing (#243) -
Add a new
update-db
command which adds any new tables and/or adds any new columns to existing tables in a flux-accounting database (#244)
- Fix memory corruption due to use-after-free of the "DNE" bank entry (#233)
- Add queue priority to job priority calculation (#207)
-
Fix incorrect job usage calculation for users who belong to multiple banks (#219)
-
Update the
pop-db
command to include themax_active_jobs
,max_running_jobs
limits defined in theassociation_table
(#224) -
Remove the unused ‘deleted’ column from the
association_table
in the flux-accounting DB (#224) -
Fix the default value for the
--queues
optional argument in theedit-user
command (#225)
-
Add an
rc1
script that populates multi-factor priority plugin with flux-accounting DB information on instance startup or restart (#223) -
Allow multi-factor priority plugin to be loaded and hold jobs without user/bank information (#227)
-
Fix incorrect listing of column names when printing table information in the flux-accounting database (#203)
-
Fix
TypeError
when not specifying a value for an optional argument for theupdate-usage
command (#209) -
Fix incorrect parsing of the
count_ranks()
helper function when updating job usage values (#211)
-
Add a new
max_active_jobs
limit for user/bank combos in the multi-factor priority plugin (#201) -
Add a new distcheck builder to flux-accounting CI (#206)
-
Improve sharness tests to use
flux account
commands directly in tests (#180) -
Change positional and optional arguments in
edit-user
command to align with otheredit-*
commands (#181) -
Fix bug in
view-user
preventing the ability to view more than one row if a user belonged to more than one bank (#187) -
Remove outdated
admin_level
column from association_table in flux-accounting database (#188) -
Fix incorrect listing of association_table headers in the
view-user
command (#193) -
Fix
UNIQUE constraint
failure when re-adding a previously deleted user to the same bank in the flux-accounting database (#193) -
Convert the
qos
argument into positional arguments for both theview-qos
andedit-qos
commands (#193)
-
Add new enforcement policy in multi-factor priority plugin to only count running jobs towards an "active" jobs counter (#177)
-
Add section to top-level README on flux-accounting database permissions (#188)
-
Add new optional arguments to
view-bank
command to view sub bank hierarchy trees or users belonging to a specific bank (#194) -
Add bulk database populate tool to upload multiple user or bank rows at one time via
.csv
file (#195)
-
Improve bulk update script by reducing number of sent payloads to just one payload containing all required data needed by multi-factor priority plugin (#167)
-
Drop
ax_python_devel.m4
and adjustconfigure.ac
since flux-accounting does not usePYTHON_CFLAGS
orPYTHON_LIBS
and rejects python3.10.0
as too old (#173) -
Add LLNL code release number to flux-accounting (#175)
- Add support for defining, configuring, and editing queues and its various limits within the flux-accounting database (#176)
-
Replace the "strict" merge mode with queue+rebase in Mergify (#158)
-
Add missing installation of the Python bulk update script that sends updated database information to the priority plugin (#162)
-
Change names of all automatic update scripts to fall under one prefix called "account" (#162)
-
Change the default DB path for all flux-accounting subcommands (#170)
-
Remove the positional argument for the
create-db
subcommand (#170) -
Unify the optional database path arguments for all of the
flux account
commands (#171)
- Add new instructions to the top-level README on setting up the flux-accounting database, loading the priority plugin, and configuring the automatic update scripts (#157)
-
Fix bug in add-user where wrong number of arguments were passed to function (#140)
-
Fix bug in edit-user to ensure an edit made in one user/bank row was only made in just that one row instead of in multiple rows in the flux-accounting database (#140)
-
Add a new front-end update script that will re-calculate users' fairshare values and update them in the flux-accounting database (#138)
-
Add new Quality of Service table in the flux-accounting database, which will hold Quality of Services and their associated priorities (#143)
-
Add new sharness tests for Python subcommands (#140)
-
Remove pandas dependency from flux-accounting, which was required to build/install (#144)
-
Fix bug where users couldn't be added due to a broken function header (#140)
-
Fix bug where a bank's shares could not be edited (#140)
-
Add a new multi-factor priority plugin that will calculate and push a user's job priority using multiple factors (#122)
-
Add a new external service that grabs flux-accounting database information and pushes it to the multi-factor priority plugin (#122)
-
Add a max jobs limit to the priority plugin that will enforce a limit of active jobs on a user/bank combination in the flux-accounting database (#131)
-
Add a new STDOUT writer class to write user/bank information from a flux-accounting database to STDOUT (#120)
-
Updated headers of source files in the
fairness
directory (#113) -
Fixed module/dependency installation strategy of flux-accounting on the
bionic
Docker image (#114) -
Fixed bug where old job usage values incorrectly included old factors when applying a decay value (#118)
-
Fixed bug where the all job usage factors were incorrectly updated multiple times in one half-life period (#118)
-
Fixed bug where a historical job usage value was updated even in the case where no new jobs were found in the current half-life period (#118)
-
Fixed bug where the last seen job timestamp was reset to 0 if no new jobs were found for a user (#118)
-
Added a new
fairshare
field to theassociation_table
in a flux-accounting database (#116) -
Added a new
writer
class which will update associations with up-to-date fairshare information (#116)- Added a subclass
data_writer_db
which will write fairshare information to a flux-accounting SQLite database
- Added a subclass
-
Added a new subcommand to
flux account
that calculates and updates historical job usage values for every association in the flux-accounting database (#118)
-
Fixed
ModuleNotFound
error when running Python unit tests on Python3.6
(#106) -
Removed shebang line from flux-account.py to prevent Python version mismatch errors (#101)
-
Added a new
reader
class which will read flux-accounting information and load it to aweighted_tree
object (#103)- Added a subclass
data_reader_db
which will read and load information from a flux-accounting SQLite database
- Added a subclass
-
Added a new flux subcommand:
flux shares
, which will output a flux-accounting database hierarchy containing user/bank shares and usage information (#109)
-
Unused variables and imports removed, license in
src/fairness/
changed to LGPL (#90) -
Behavior of
delete-user
,delete-bank
changed to keep job history of a user after they are removed from the flux-accounting DB (#92) -
bank
argument added to thedelete-user
subcommand (#95)
-
unittest.mock()
integrated with job-archive interface unit tests (#93) -
flux-accounting database can be loaded into weighted tree library to generate fairshare values for users (#97)
-
print-hierarchy
's error output more graceful when there are no accounts (#62) -
association_table
'suser_name
field changed tousername
(#67) -
accounting_cli.py's
account
option changed tobank
(#70) -
variables in print_hierarchy.cpp moved from
global
scope (#71) -
Python code converted over to use autotools, TAP, and sharness (#73)
-
print-hierarchy
added as a C++ implementation to weighted tree lib (#64) -
delete-bank
recursively deletes sub banks and associations when a parent bank is deleted (#78) -
calc_usage_factor()
calculates a user's historical job usage value based on their job history (#79)
-
view-job-records
subcommand parameters adjusted to be unpacked as a dictionary (#55) -
Move
view_job_records()
and its helper functions into its own Python module (#57)
-
Add a library that provides a weighted tree-based fairness (#65)
-
Add autogen, automake tools to flux-accounting repo (#65)
-
bank_table
's primary key is now a fixed type (#42) -
bank_table
's subcommands no longer impose constraints on values of shares (#44) -
print-hierarchy
's format improved to represent a bank and user hierarchy (#51)
This release adds a new table to the flux-accounting database and a front end to flux-core's job-archive.
-
Add a new table
bank_table
that stores bank information for users to charge jobs against. -
Add a front-end interface to flux-core's job-archive to fetch job record information and sort it with customizable parameters, such as by username, before or after a specific time, or with a specific job ID.
Initial release.
-
Create an accounting database which stores user account information. Can interact with database through SQLite shell or through a command line interface to add and remove users, edit account values, and view account information.
-
Add Makefile to allow flux-accounting to be installed alongside flux-core so that flux-accounting commands can be picked up by Flux's command driver.