Commit Graph

86 Commits (7d483d87df66bdc628356ff7a2bf232dd9488d77)

Author SHA1 Message Date
Chris Goller adb071be37 Refactor queryConfig fields to kapacitor to remove loops 2017-10-17 13:48:21 -05:00
Chris Goller 5711fe66f2 Update kapacitor variables to guard against invalid fields 2017-10-16 12:02:47 -05:00
Chris Goller 14e49c0ef9 Rename queryConfig field to Value and support top/bottom 2017-10-16 10:56:12 -05:00
Chris Goller 0d3762e272 WIP supporting integers/floats for influxql arguments 2017-10-11 14:45:01 -05:00
Chris Goller 7f3986f982 Refactor query config field arguments to be fields 2017-10-10 18:04:45 -05:00
Chris Goller 5f4ce64a11 Refactor queryConfig to have field aliases and function arguments 2017-10-10 17:01:50 -05:00
Chris Goller 6d2068b79d Update Kapacitor rule POST/PUT to allow raw tickscripts without
queryConfig
2017-09-09 10:19:52 -05:00
Chris Goller a28d3d6466 Update kapacitor AlertRule to containe most Kapacitor Task information 2017-09-09 10:19:52 -05:00
Chris Goller 2128c13163 Update kapacitor rule response with dbrps, various dates, error, and executing. 2017-09-09 10:19:52 -05:00
Chris Goller 39014cd3b2 Update kapacitor client tests to use Task scheme 2017-09-09 10:19:52 -05:00
Chris Goller 0c2e7f385b WIP 2017-09-09 10:19:52 -05:00
Chris Goller 8a87628e37 WIP 2017-09-09 10:19:52 -05:00
Tim Raymond 31abf6dfd8 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 a3db471abe
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 d560ab020a 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 c3be40513d 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 81f9e410f9 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 01596453bd Update comment
Variable name changed. Improved clarity.
2017-08-18 16:44:04 -04:00
Tim Raymond 886046ed9a
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 d0be50ab37
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 4a20c28baf Add space between functions 2017-07-21 19:57:31 -07:00
Jared Scheib 918dff33b7 Merge pull request #1724 from influxdata/feature/pushover_support-1680
Add Pushover alert support
2017-07-21 14:04:22 -07:00
Jared Scheib 9def502082 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 2cacc2507d Update Kapacitor AST extract handlers to also guard against empty slices 2017-07-21 13:53:23 -07:00
Jared Scheib 928c4c2764 Fix and remove invalid Pushover alert node keys 2017-07-20 14:59:56 -07:00
Jared Scheib a34ccb0189 Extract Pushover properties for Kapa alert via AST 2017-07-17 17:30:12 -07:00
Jared Scheib 0522bcdd60 Add Pushover as valid Kapacitor handler endpoint type 2017-07-17 17:29:26 -07:00
Chris Goller c7ffac61a6 Update kapacitor alerts and ast to 1.3.1 features. 2017-07-14 21:09:39 -05:00
Andrew Watkins 02c63320f3 Add test for disabled bug 2017-06-20 11:42:19 -07:00
Andrew Watkins 7c22dfb09e Fix enable / disable bug 2017-06-20 11:08:39 -07:00
Chris Goller fcd334a214 Add test coverage to kapacitor client 2017-05-25 16:04:50 -05:00
Chris Goller 8d8ffd2bf5 Fix kapacitor PUT/POST returning request rather than response 2017-05-24 15:30:45 -07:00
Max Chadwick 2595a223ef Test kapacitor log extraction 2017-05-14 22:09:15 -04:00
Max Chadwick 1416d617b1 Extract log from alerts 2017-05-14 22:01:08 -04:00
Max Chadwick 2b8abf1651 Add log alert tests 2017-05-14 21:42:41 -04:00
Max Chadwick 90afb717da Add ability to log alerts 2017-05-12 22:04:38 -04:00
Chris Goller d16286c505 Fix null queryConfig and add substantial test coverage to kapacitor
storage
2017-05-05 16:14:02 -05:00
Chris Goller 8aaed06402 Update Kapacitor alerts to set queryConfig to null if not parsable. 2017-05-05 14:30:20 -05:00
Andrew Watkins 014103adf6 Resolve conflicts
Conflicts:
	ui/src/utils/influxql.js
2017-05-05 10:01:26 -07:00
Chris Goller 65231c2409 Update rawtext in queryconfig to be null and not omitempty 2017-04-07 17:32:10 -05:00
Chris Goller 88bd59d71a Add ID for each kapacitor rule 2017-04-05 23:19:06 -05:00
Chris Goller e83d95b937 Update kapacitors rule's to use AST and kapacitor directly 2017-04-05 20:04:42 -05:00
Chris Goller b769370ce6 Add kapacitor AST tests for relative and deadman 2017-04-05 09:06:52 -05:00
Chris Goller 85ded628cd Fix kapacitor AST regex parsing 2017-04-04 14:44:59 -05:00
Chris Goller 6ef73889b9 Add more tests to kapacitor AST to queryConfig 2017-04-04 10:58:11 -05:00
Chris Goller 293a1c5ee9 Add full kapacitor ast to chronograf.AlertRule with tests 2017-04-03 23:11:18 -05:00
Chris Goller 6864b039b4 Add alert nodes to kapacitor AST 2017-04-03 18:19:15 -05:00
Chris Goller 56378b4846 Add variable parsing for kapacitor AST 2017-04-03 10:40:10 -05:00
Chris Goller c327337643 Add initial reversing of TICKscript to query config 2017-03-27 14:21:57 -05:00
Chris Goller b60901e766 Add structured logging to underlying http server 2017-03-06 15:16:45 -06:00