Commit Graph

80 Commits (ba5f10a9fbc00eb60848f0feb248cfe5e3831bbb)

Author SHA1 Message Date
Chris Goller 153028a830 Update Kapacitor rule POST/PUT to allow raw tickscripts without
queryConfig
2017-09-09 10:19:52 -05:00
Chris Goller 35248b8044 Update kapacitor AlertRule to containe most Kapacitor Task information 2017-09-09 10:19:52 -05:00
Chris Goller d1007513cd Update kapacitor rule response with dbrps, various dates, error, and executing. 2017-09-09 10:19:52 -05:00
Chris Goller 577403f16e Update kapacitor client tests to use Task scheme 2017-09-09 10:19:52 -05:00
Chris Goller bebe0f364a WIP 2017-09-09 10:19:52 -05:00
Chris Goller 86366741fd WIP 2017-09-09 10:19:52 -05:00
Tim Raymond 1d75235fe1 Explain magic number, var renaming
This extracts a constant and comments it for clarity. Also renames a
confusing waitgroup
2017-08-23 16:32:00 -04:00
Tim Raymond 8ae3dc35cc Extract option generator and task fetcher
The option generator goroutine and the task fetcher goroutine are more
readable when extracted into another method. Also, added some commenting
documenting what their expectations are
2017-08-23 16:21:13 -04:00
Tim Raymond fe57d1e0c7 Improve benchmark, fix offset bug
This ensures that setup time does not impact the results of the
benchmark since profiling showed that much time was spent setting up the
test array of tasks. This also uses `make` to build that slice instead.

Also, the tests revealed that there was a bug where offsets were
pre-incremented rather than post-incremented, omitting the first 100
results.
2017-08-22 10:23:24 -04:00
Tim Raymond 0d2991d719 Perf: improve performance of ListTasks
This fetches ListTasks results using a few worker goroutines to improve
performance with large numbers of tasks.
2017-08-21 17:10:13 -04:00
Tim Raymond f7291550c0 Fix issue where offset & limit won't work
Because we were testing the mock client, and not the paginating
kapacitor client for the case where limit and offset were provided, an
issue with that code path was not exposed.

The issues exposed were that the condition was incorrect for triggering
this behavior, and no return clause was present to prevent the remainder
of the ListTasks method from running.
2017-08-18 17:07:00 -04:00
Tim Raymond 4bfd982a23 Update comment
Variable name changed. Improved clarity.
2017-08-18 16:44:04 -04:00
Tim Raymond 9b71477509 Switch KapacitorRulesGet to use Pagination
Kapacitor responses are paginated, and sometimes users have more than
the default 100 tasks that are returned from Kapacitor. This replaces
the previous Kapa client with one that automatically follows paginated
responses from Kapacitor's ListTasks endpoint and returns the full
response.

Tests for the KapacitorRulesGet endpoint had to be updated because they
did not account for "limit" and "offset", and so led to an infinite
loop with the paginated client. A correct kapacitor backend will not
have this behavior
2017-08-15 17:30:29 -04:00
Tim Raymond fcf325bbbe Add PaginatingKapacitorClient
The kapacitor client used in the kapacitor endpoints is limited to
fetching whatever limit you provide it. If you provide no limit, it
defaults to a limit of 100. We use this default behavior currently.

Some users have more than 100 tasks, so we need a client that's capable
of continually fetching tasks from Kapacitor until there are none left,
and returning the full response to the frontend.

This introduces a PaginatingKapacitorClient which does exactly that.
Also, test coverage was added around the KapacitorRulesGet endpoint,
since it was previously untested.
2017-08-15 16:55:47 -04:00
Jared Scheib f6aed4ae84 Add space between functions 2017-07-21 19:57:31 -07:00
Jared Scheib d6db7ee084 Merge pull request #1724 from influxdata/feature/pushover_support-1680
Add Pushover alert support
2017-07-21 14:04:22 -07:00
Jared Scheib 62096e7561 Fix PagerDuty kapacitor node typo bug (#1751)
* Fix pagerduty kapacitor node typo bug

* Update changelog
2017-07-21 13:54:49 -07:00
Jared Scheib f1d486733d Update Kapacitor AST extract handlers to also guard against empty slices 2017-07-21 13:53:23 -07:00
Jared Scheib 1fbea1e84e Fix and remove invalid Pushover alert node keys 2017-07-20 14:59:56 -07:00
Jared Scheib 40ad225752 Extract Pushover properties for Kapa alert via AST 2017-07-17 17:30:12 -07:00
Jared Scheib ed883cffa6 Add Pushover as valid Kapacitor handler endpoint type 2017-07-17 17:29:26 -07:00
Chris Goller 4432a8227e Update kapacitor alerts and ast to 1.3.1 features. 2017-07-14 21:09:39 -05:00
Andrew Watkins e1aef32512 Add test for disabled bug 2017-06-20 11:42:19 -07:00
Andrew Watkins 8e35b84ef9 Fix enable / disable bug 2017-06-20 11:08:39 -07:00
Chris Goller 1705c6fd07 Add test coverage to kapacitor client 2017-05-25 16:04:50 -05:00
Chris Goller d19f8062ec Fix kapacitor PUT/POST returning request rather than response 2017-05-24 15:30:45 -07:00
Max Chadwick efbee30d9c Test kapacitor log extraction 2017-05-14 22:09:15 -04:00
Max Chadwick 0af4a4d47b Extract log from alerts 2017-05-14 22:01:08 -04:00
Max Chadwick 204a06e7ea Add log alert tests 2017-05-14 21:42:41 -04:00
Max Chadwick 34ad6f54d5 Add ability to log alerts 2017-05-12 22:04:38 -04:00
Chris Goller 243286892f Fix null queryConfig and add substantial test coverage to kapacitor
storage
2017-05-05 16:14:02 -05:00
Chris Goller 3821b1ccff Update Kapacitor alerts to set queryConfig to null if not parsable. 2017-05-05 14:30:20 -05:00
Andrew Watkins 92bd5d10b4 Resolve conflicts
Conflicts:
	ui/src/utils/influxql.js
2017-05-05 10:01:26 -07:00
Chris Goller 313f7e94ca Update rawtext in queryconfig to be null and not omitempty 2017-04-07 17:32:10 -05:00
Chris Goller 95d8903144 Add ID for each kapacitor rule 2017-04-05 23:19:06 -05:00
Chris Goller 46f4f43692 Update kapacitors rule's to use AST and kapacitor directly 2017-04-05 20:04:42 -05:00
Chris Goller 870ae7913b Add kapacitor AST tests for relative and deadman 2017-04-05 09:06:52 -05:00
Chris Goller 02b371741f Fix kapacitor AST regex parsing 2017-04-04 14:44:59 -05:00
Chris Goller 9206935d75 Add more tests to kapacitor AST to queryConfig 2017-04-04 10:58:11 -05:00
Chris Goller a449a74c72 Add full kapacitor ast to chronograf.AlertRule with tests 2017-04-03 23:11:18 -05:00
Chris Goller cbc5ee5e13 Add alert nodes to kapacitor AST 2017-04-03 18:19:15 -05:00
Chris Goller caf806908d Add variable parsing for kapacitor AST 2017-04-03 10:40:10 -05:00
Chris Goller d930961d32 Add initial reversing of TICKscript to query config 2017-03-27 14:21:57 -05:00
Chris Goller 49d8ece940 Add structured logging to underlying http server 2017-03-06 15:16:45 -06:00
Chris Goller 9ac300cf19 Update to fix go linter issues 2017-03-06 10:11:52 -06:00
Chris Goller a0352b1e7d Add disable and enable to kapacitor alerts 2017-02-10 13:48:42 -06:00
Chris Goller 27bafdab53 Update function name for kapacitor's formatting of values 2017-02-10 10:06:26 -06:00
Chris Goller 2d4228fd82 Add handling of string values for kapacitor threshold alerts 2017-02-10 08:47:08 -06:00
Chris Goller eebb27c507 Add exec to supported kapacitor alerts 2017-02-09 00:29:19 -06:00
Chris Goller 7b15168fb1 Update kapacitor alert generation to support alerta 2017-02-09 00:23:46 -06:00