diff --git a/sake b/sake index 3fac1c4119a..3e1274d8cfb 100755 --- a/sake +++ b/sake @@ -90,7 +90,6 @@ if [ "$1" = "-start" ]; then url=$3 fi - # TODO: Give a globally unique processname by including the projectname as well processname=$2 daemon -n $processname -r -D $base --pidfile=$pidfile --stdout=$outlog --stderr=$errlog $sake $url @@ -105,7 +104,6 @@ if [ "$1" = "-stop" ]; then if [ -f $pidfile ]; then echo "Stopping service $2" - # TODO: This is a bad way of killing the process kill -KILL `cat $pidfile` unlink $pidfile else diff --git a/src/Control/ContentNegotiator.php b/src/Control/ContentNegotiator.php index 3e17d06d4f2..21ec89f3e6b 100644 --- a/src/Control/ContentNegotiator.php +++ b/src/Control/ContentNegotiator.php @@ -25,10 +25,6 @@ * * Please see http://webkit.org/blog/68/understanding-html-xml-and-xhtml/ for further information. * - * @todo Check for correct XHTML doctype in xhtml() - * @todo Allow for other HTML4 doctypes (e.g. Transitional) in html() - * @todo Make content replacement and doctype setting two separately configurable behaviours - * * Some developers might know what they're doing and don't want ContentNegotiator messing with their * HTML4 doctypes, but still find it useful to have self-closing tags removed. */ @@ -169,8 +165,6 @@ public static function process(HTTPResponse $response) * , checked, selected). * * @param HTTPResponse $response - * - * @todo Search for more xhtml replacement */ public function xhtml(HTTPResponse $response) { diff --git a/src/Control/Controller.php b/src/Control/Controller.php index da5a6726694..80d7047c06c 100644 --- a/src/Control/Controller.php +++ b/src/Control/Controller.php @@ -146,8 +146,6 @@ public function setRequest(HTTPRequest $request): static /** * A bootstrap for the handleRequest method * - * @todo setDataModel and setRequest are redundantly called in parent::handleRequest() - sort this out - * * @param HTTPRequest $request */ protected function beforeHandleRequest(HTTPRequest $request) diff --git a/src/Control/CookieJar.php b/src/Control/CookieJar.php index 0009e09dc16..c2667bfcb9c 100644 --- a/src/Control/CookieJar.php +++ b/src/Control/CookieJar.php @@ -11,10 +11,6 @@ * This backend allows one to better test Cookie setting and separate cookie * handling from the core * - * @todo Create a config array for defaults (eg: httpOnly, secure, path, domain, expiry) - * @todo A getter for cookies that haven't been sent to the browser yet - * @todo Tests / a way to set the state without hacking with $_COOKIE - * @todo Store the meta information around cookie setting (path, domain, secure, etc) */ class CookieJar implements Cookie_Backend { diff --git a/src/Control/HTTP.php b/src/Control/HTTP.php index 0fa24e060cd..d13bd7728be 100644 --- a/src/Control/HTTP.php +++ b/src/Control/HTTP.php @@ -121,7 +121,6 @@ public static function urlRewriter($content, $code) $regExps[] = "/(<{$tagPrefix}[^>]*$attrib *= *)([^\"' ]*)( )/i"; } // Replace css styles - // @todo - http://www.css3.info/preview/multiple-backgrounds/ $styles = ['background-image', 'background', 'list-style-image', 'list-style', 'content']; foreach ($styles as $style) { $regExps[] = "/($style:[^;]*url *\\(\")([^\"]+)(\"\\))/i"; diff --git a/src/Control/Middleware/HTTPCacheControlMiddleware.php b/src/Control/Middleware/HTTPCacheControlMiddleware.php index 4c7f0ab5a6b..94fb0e2c3b3 100644 --- a/src/Control/Middleware/HTTPCacheControlMiddleware.php +++ b/src/Control/Middleware/HTTPCacheControlMiddleware.php @@ -28,8 +28,6 @@ class HTTPCacheControlMiddleware implements HTTPMiddleware, Resettable /** * Generate response for the given request * - * @todo Refactor HTTP::add_cache_headers() (e.g. etag handling) into this middleware - * * @param HTTPRequest $request * @param callable $delegate * @return HTTPResponse diff --git a/src/Control/RSS/RSSFeed.php b/src/Control/RSS/RSSFeed.php index 597a1f09acb..c397f545457 100644 --- a/src/Control/RSS/RSSFeed.php +++ b/src/Control/RSS/RSSFeed.php @@ -18,7 +18,6 @@ * RSSFeed class * * This class is used to create an RSS feed. - * @todo Improve documentation */ class RSSFeed extends ViewableData { @@ -215,8 +214,6 @@ public function Description() /** * Output the feed to the browser. * - * TODO: Pass $response object to ->outputToBrowser() to loosen dependence on global state for easier testing/prototyping so dev can inject custom HTTPResponse instance. - * * @return DBHTMLText */ public function outputToBrowser() diff --git a/src/Control/RequestHandler.php b/src/Control/RequestHandler.php index e724f74945e..872c6a05bae 100644 --- a/src/Control/RequestHandler.php +++ b/src/Control/RequestHandler.php @@ -171,8 +171,6 @@ public function handleRequest(HTTPRequest $request) // We used to put "handleAction" as the action on controllers, but (a) this could only be called when // you had $Action in your rule, and (b) RequestHandler didn't have one. $Action is better if ($action == 'handleAction') { - // TODO Fix LeftAndMain usage - // Deprecation::notice('3.2.0', 'Calling handleAction directly is deprecated - use $Action instead'); $action = '$Action'; } diff --git a/src/Control/SimpleResourceURLGenerator.php b/src/Control/SimpleResourceURLGenerator.php index ae4b59cb45d..c41f68ef36c 100644 --- a/src/Control/SimpleResourceURLGenerator.php +++ b/src/Control/SimpleResourceURLGenerator.php @@ -140,7 +140,6 @@ protected function resolveModuleResource(ModuleResource $resource) // All resources mapped directly to _resources/ $relativePath = Path::join(RESOURCES_DIR, $relativePath); } elseif (stripos($relativePath ?? '', ManifestFileFinder::VENDOR_DIR . DIRECTORY_SEPARATOR) === 0) { - // @todo Non-public dir support will be removed in 5.0, so remove this block there // If there is no public folder, map to _resources/ but trim leading vendor/ too (4.0 compat) $relativePath = Path::join( RESOURCES_DIR, diff --git a/src/Core/BaseKernel.php b/src/Core/BaseKernel.php index 2b7ffbd2e9d..c6fd4c60143 100644 --- a/src/Core/BaseKernel.php +++ b/src/Core/BaseKernel.php @@ -114,7 +114,6 @@ public function __construct($basePath) $this->setModuleLoader($moduleLoader); // Config loader - // @todo refactor CoreConfigFactory $configFactory = new CoreConfigFactory($manifestCacheFactory); $configManifest = $configFactory->createRoot(); $configLoader = ConfigLoader::inst(); diff --git a/src/Core/ClassInfo.php b/src/Core/ClassInfo.php index 2e196710a3f..7c8094d0f0e 100644 --- a/src/Core/ClassInfo.php +++ b/src/Core/ClassInfo.php @@ -82,8 +82,6 @@ public static function exists($class) } /** - * @todo Move this to SS_Database or DB - * * @param string $tableName * @return bool */ @@ -130,8 +128,6 @@ public static function getValidSubClasses($class = SiteTree::class, $includeUnba * Returns an array of the current class and all its ancestors and children * which require a DB table. * - * @todo Move this into {@see DataObjectSchema} - * * @param string|object $nameOrObject Class or object instance * @return array */ diff --git a/src/Core/Convert.php b/src/Core/Convert.php index 161750ae20e..0a625bb8664 100644 --- a/src/Core/Convert.php +++ b/src/Core/Convert.php @@ -204,7 +204,6 @@ public static function symbol2sql($identifier, $separator = '.') * Warning: Does not decode array keys * * @uses html2raw() - * @todo Currently &#xxx; entries are stripped; they should be converted * @param mixed $val * @return array|string */ diff --git a/src/Core/Extensible.php b/src/Core/Extensible.php index 3d80cb714a4..91bf23ce2a9 100644 --- a/src/Core/Extensible.php +++ b/src/Core/Extensible.php @@ -217,8 +217,6 @@ public static function add_extension($classOrExtension, $extension = null) * Clears any previously created singletons through {@link singleton()} * to avoid side-effects from stale extension information. * - * @todo Add support for removing extensions with parameters - * * @param string $extension class name of an {@link Extension} subclass, without parameters */ public static function remove_extension($extension) diff --git a/src/Core/Injector/Injector.php b/src/Core/Injector/Injector.php index 75b971d0ca5..75cbf79988c 100644 --- a/src/Core/Injector/Injector.php +++ b/src/Core/Injector/Injector.php @@ -666,10 +666,6 @@ protected function instantiate($spec, $id = null, $type = null) /** * Inject $object with available objects from the service cache * - * @todo Track all the existing objects that have had a service bound - * into them, so we can update that binding at a later point if needbe (ie - * if the managed service changes) - * * @param object $object * The object to inject * @param string $asType diff --git a/src/Dev/BulkLoader.php b/src/Dev/BulkLoader.php index 43961e286c1..3b9d357d995 100644 --- a/src/Dev/BulkLoader.php +++ b/src/Dev/BulkLoader.php @@ -12,10 +12,6 @@ * * You can configure column-handling, * - * @todo Add support for adding/editing has_many relations. - * @todo Add support for deep chaining of relation properties (e.g. Player.Team.Stats.GoalCount) - * @todo Character conversion - * * @see http://tools.ietf.org/html/rfc4180 * @author Ingo Schommer, Silverstripe Ltd. (@silverstripe.com) */ @@ -217,7 +213,6 @@ public function Title() * ] * * - * @todo Mix in custom column mappings * * @return array **/ diff --git a/src/Dev/BulkLoader_Result.php b/src/Dev/BulkLoader_Result.php index 333c89a2af8..be1b1251602 100644 --- a/src/Dev/BulkLoader_Result.php +++ b/src/Dev/BulkLoader_Result.php @@ -11,8 +11,6 @@ * Encapsulates the result of a {@link BulkLoader} import * (usually through the {@link BulkLoader->processAll()} method). * - * @todo Refactor to support lazy-loaded DataObjectSets once they are implemented. - * * @author Ingo Schommer, Silverstripe Ltd. (@silverstripe.com) */ class BulkLoader_Result implements \Countable diff --git a/src/Dev/CliDebugView.php b/src/Dev/CliDebugView.php index 7347eec4885..44121bf780a 100644 --- a/src/Dev/CliDebugView.php +++ b/src/Dev/CliDebugView.php @@ -9,8 +9,6 @@ /** * A basic HTML wrapper for stylish rendering of a development info view. * Used to output error messages, and test results. - * - * @todo Perhaps DebugView should be an interface / ABC, implemented by HTMLDebugView and CliDebugView? */ class CliDebugView extends DebugView { diff --git a/src/Dev/Constraint/ViewableDataContains.php b/src/Dev/Constraint/ViewableDataContains.php index af114365b25..97bc26e50fe 100644 --- a/src/Dev/Constraint/ViewableDataContains.php +++ b/src/Dev/Constraint/ViewableDataContains.php @@ -74,8 +74,6 @@ public function evaluate($other, $description = '', $returnResult = false): ?boo /** * Returns a string representation of the object. - * - * @todo: add representation for more than one match */ public function toString(): string { diff --git a/src/Dev/CsvBulkLoader.php b/src/Dev/CsvBulkLoader.php index ae8b7bb88e1..683534449a4 100644 --- a/src/Dev/CsvBulkLoader.php +++ b/src/Dev/CsvBulkLoader.php @@ -15,9 +15,6 @@ * input. * * @see http://tools.ietf.org/html/rfc4180 - * - * @todo Support for deleting existing records not matched in the import - * (through relation checks) */ class CsvBulkLoader extends BulkLoader { @@ -160,9 +157,6 @@ protected function getNormalisedColumnMap() } /** - * @todo Better messages for relation checks and duplicate detection - * Note that columnMap isn't used. - * * @param array $record * @param array $columnMap * @param BulkLoader_Result $results @@ -261,7 +255,6 @@ protected function processRecord($record, $columnMap, &$results, $preview = fals $obj->write(); } - // @todo better message support $message = ''; // save to results @@ -289,8 +282,6 @@ protected function processRecord($record, $columnMap, &$results, $preview = fals * Find an existing objects based on one or more uniqueness columns * specified via {@link self::$duplicateChecks}. * - * @todo support $columnMap - * * @param array $record CSV data column * @param array $columnMap * @return DataObject diff --git a/src/Dev/Debug.php b/src/Dev/Debug.php index eb0be06e1a9..2f759d512cd 100644 --- a/src/Dev/Debug.php +++ b/src/Dev/Debug.php @@ -25,9 +25,6 @@ * Errors handled by this class are passed along to {@link SS_Log}. * For configuration information, see the {@link SS_Log} * class documentation. - * - * @todo add support for user defined config: Debug::die_on_notice(true | false) - * @todo better way of figuring out the error context to display in highlighted source */ class Debug { @@ -212,7 +209,6 @@ public static function require_developer_login() // being called again. // This basically calls Permission::checkMember($_SESSION['loggedInAs'], 'ADMIN'); - // @TODO - Rewrite safely using DataList::filter $memberID = $_SESSION['loggedInAs']; $permission = DB::prepared_query( ' diff --git a/src/Dev/DevelopmentAdmin.php b/src/Dev/DevelopmentAdmin.php index 79b2e1c7093..ba135c3c6d2 100644 --- a/src/Dev/DevelopmentAdmin.php +++ b/src/Dev/DevelopmentAdmin.php @@ -19,11 +19,6 @@ * * Configured in framework/_config/dev.yml, with the config key registeredControllers being * used to generate the list of links for /dev. - * - * @todo documentation for how to add new unit tests and tasks - * @todo do we need buildDefaults and generatesecuretoken? if so, register in the list - * @todo cleanup errors() it's not even an allowed action, so can go - * @todo cleanup index() html building */ class DevelopmentAdmin extends Controller { diff --git a/src/Dev/State/ExtensionTestState.php b/src/Dev/State/ExtensionTestState.php index 1c8a62c6497..0cf274367a7 100644 --- a/src/Dev/State/ExtensionTestState.php +++ b/src/Dev/State/ExtensionTestState.php @@ -104,9 +104,6 @@ public function setUpOnce($class) public function tearDownOnce($class) { - // @todo: This isn't strictly necessary to restore extensions, but only to ensure that - // Object::$extra_methods is properly flushed. This should be replaced with a simple - // flush mechanism for each $class. /** @var string|DataObject $dataClass */ // Remove extensions added for testing diff --git a/src/Forms/CheckboxSetField.php b/src/Forms/CheckboxSetField.php index 00925a622f6..765737e3e51 100644 --- a/src/Forms/CheckboxSetField.php +++ b/src/Forms/CheckboxSetField.php @@ -36,11 +36,6 @@ * the database records. * - If the field name matches a database field, a comma-separated list of values will be saved to that field. The * keys can be text or numbers. - * - * @todo Document the different source data that can be used - * with this form field - e.g ComponentSet, ArrayList, - * array. Is it also appropriate to accept so many different - * types of data when just using an array would be appropriate? */ class CheckboxSetField extends MultiSelectField { @@ -48,9 +43,6 @@ class CheckboxSetField extends MultiSelectField protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_MULTISELECT; /** - * @todo Explain different source data that can be used with this field, - * e.g. SQLMap, ArrayList or an array. - * * @param array $properties * @return DBHTMLText */ diff --git a/src/Forms/CompositeField.php b/src/Forms/CompositeField.php index 0e2c4b35a14..d1f9bbf8bd7 100644 --- a/src/Forms/CompositeField.php +++ b/src/Forms/CompositeField.php @@ -121,8 +121,6 @@ public function getChildren() * If the CompositeField doesn't have a name, but we still want the ID/name to be set. * This code generates the ID from the nested children. * - * @todo this is temporary, and should be removed when FormTemplateHelper is updated to handle ID for CompositeFields with no name - * * @return String $name */ public function getName() diff --git a/src/Forms/CurrencyField.php b/src/Forms/CurrencyField.php index c340fce7bf8..5d36cf8edb3 100644 --- a/src/Forms/CurrencyField.php +++ b/src/Forms/CurrencyField.php @@ -9,8 +9,6 @@ * Limited to US-centric formats, including a hardcoded currency * symbol and decimal separators. * See {@link MoneyField} for a more flexible implementation. - * - * @todo Add localization support, see http://open.silverstripe.com/ticket/2931 */ class CurrencyField extends TextField { diff --git a/src/Forms/DefaultFormFactory.php b/src/Forms/DefaultFormFactory.php index 669f1cdeb55..8b737d0481e 100644 --- a/src/Forms/DefaultFormFactory.php +++ b/src/Forms/DefaultFormFactory.php @@ -67,7 +67,6 @@ public function getForm(RequestHandler $controller = null, $name = FormFactory:: protected function getFormFields(RequestHandler $controller = null, $name, $context = []) { // Fall back to standard "getCMSFields" which itself uses the FormScaffolder as a fallback - // @todo Deprecate or formalise support for getCMSFields() $fields = $context['Record']->getCMSFields(); $this->invokeWithExtensions('updateFormFields', $fields, $controller, $name, $context); return $fields; @@ -83,7 +82,6 @@ protected function getFormFields(RequestHandler $controller = null, $name, $cont */ protected function getFormActions(RequestHandler $controller = null, $name, $context = []) { - // @todo Deprecate or formalise support for getCMSActions() $actions = $context['Record']->getCMSActions(); $this->invokeWithExtensions('updateFormActions', $actions, $controller, $name, $context); return $actions; diff --git a/src/Forms/FieldGroup.php b/src/Forms/FieldGroup.php index a42b3889a34..46099ab1d1d 100644 --- a/src/Forms/FieldGroup.php +++ b/src/Forms/FieldGroup.php @@ -105,9 +105,6 @@ public function __construct($titleOrField = null, $otherFields = null) * Returns the name (ID) for the element. * In some cases the FieldGroup doesn't have a title, but we still want * the ID / name to be set. This code, generates the ID from the nested children - * - * TODO this is temporary, and should be removed when FormTemplateHelper is updated to handle ID - * for CompositeFields with no name */ public function getName() { diff --git a/src/Forms/FieldList.php b/src/Forms/FieldList.php index 62156bc3632..f84b3913599 100644 --- a/src/Forms/FieldList.php +++ b/src/Forms/FieldList.php @@ -411,8 +411,6 @@ public function findTab($tabName) /** * Returns the specified tab object, creating it if necessary. * - * @todo Support recursive creation of TabSets - * * @param string $tabName The tab to return, in the form "Tab.Subtab.Subsubtab". * Caution: Does not recursively create TabSet instances, you need to make sure everything * up until the last tab in the chain exists. @@ -462,8 +460,6 @@ public function findOrMakeTab($tabName, $title = null) * Returns a named field. * You can use dot syntax to get fields from child composite fields * - * @todo Implement similarly to dataFieldByName() to support nested sets - or merge with dataFields() - * * @param string $name * @return FormField|null */ diff --git a/src/Forms/FormField.php b/src/Forms/FormField.php index 763d388b804..dc14e477b16 100644 --- a/src/Forms/FormField.php +++ b/src/Forms/FormField.php @@ -123,8 +123,6 @@ class FormField extends RequestHandler * Adds a title attribute to the markup. * * @var string - * - * @todo Implement in all subclasses */ protected $description; @@ -1425,8 +1423,6 @@ public function getSchemaComponent() * * @param array $schemaData - The data to be merged with $this->schemaData. * @return FormField - * - * @todo Add deep merging of arrays like `data` and `attributes`. */ public function setSchemaData($schemaData = []) { @@ -1447,8 +1443,6 @@ public function getSchemaData() } /** - * @todo Throw exception if value is missing, once a form field schema is mandatory across the CMS - * * @return string */ public function getSchemaDataType() @@ -1501,8 +1495,6 @@ public function getSchemaDataDefaults() * * @param array $schemaState The data to be merged with $this->schemaData. * @return FormField - * - * @todo Add deep merging of arrays like `data` and `attributes`. */ public function setSchemaState($schemaState = []) { @@ -1529,7 +1521,6 @@ public function getSchemaState() * Includes validation data if the field is associated to a {@link Form}, * and {@link Form->validate()} has been called. * - * @todo Make form / field messages not always stored as html; Store value / casting as separate values. * @return array */ public function getSchemaStateDefaults() diff --git a/src/Forms/FormRequestHandler.php b/src/Forms/FormRequestHandler.php index c52ba236deb..1071f92aba8 100644 --- a/src/Forms/FormRequestHandler.php +++ b/src/Forms/FormRequestHandler.php @@ -137,7 +137,6 @@ public function httpSubmission($request) $this->form->loadDataFrom($vars, true, $allowedFields); // Protection against CSRF attacks - // @todo Move this to SecurityTokenField::validate() $token = $this->form->getSecurityToken(); if (! $token->checkRequest($request)) { $securityID = $token->getName(); diff --git a/src/Forms/FormScaffolder.php b/src/Forms/FormScaffolder.php index f88d1fb55bd..d654e73c79b 100644 --- a/src/Forms/FormScaffolder.php +++ b/src/Forms/FormScaffolder.php @@ -36,16 +36,12 @@ class FormScaffolder /** * @var array $restrictFields Numeric array of a field name whitelist. * If left blank, all fields from {@link DataObject->db()} will be included. - * - * @todo Implement restrictions for has_many and many_many relations. */ public $restrictFields; /** * @var array $fieldClasses Optional mapping of fieldnames to subclasses of {@link FormField}. * By default the scaffolder will determine the field instance by {@link DBField::scaffoldFormField()}. - * - * @todo Implement fieldClasses for has_many and many_many relations */ public $fieldClasses; @@ -87,7 +83,6 @@ public function getFieldList() continue; } - // @todo Pass localized title if ($this->fieldClasses && isset($this->fieldClasses[$fieldName])) { $fieldClass = $this->fieldClasses[$fieldName]; $fieldObject = new $fieldClass($fieldName); diff --git a/src/Forms/GridField/GridField.php b/src/Forms/GridField/GridField.php index 9b1b3731a80..19210651ccc 100644 --- a/src/Forms/GridField/GridField.php +++ b/src/Forms/GridField/GridField.php @@ -342,8 +342,6 @@ public function getComponents() /** * Cast an arbitrary value with the help of a $castingDefinition. * - * @todo refactor this into GridFieldComponent - * * @param mixed $value * @param string|array $castingDefinition * @@ -555,8 +553,6 @@ public function FieldHolder($properties = []) ]; $fragmentDeferred = []; - // TODO: Break the below into separate reducer methods - // Continue looping if any placeholders exist while (array_filter($content ?? [], function ($value) { return preg_match(self::FRAGMENT_REGEX ?? '', $value ?? ''); @@ -1182,8 +1178,6 @@ public function handleAlterAction($actionName, $arguments, $data) * Custom request handler that will check component handlers before proceeding to the default * implementation. * - * @todo copy less code from RequestHandler. - * * @param HTTPRequest $request * @return array|RequestHandler|HTTPResponse|string * @throws HTTPResponse_Exception diff --git a/src/Forms/GridField/GridFieldDetailForm_ItemRequest.php b/src/Forms/GridField/GridFieldDetailForm_ItemRequest.php index f08ee32b63e..a41dd68bb71 100644 --- a/src/Forms/GridField/GridFieldDetailForm_ItemRequest.php +++ b/src/Forms/GridField/GridFieldDetailForm_ItemRequest.php @@ -169,7 +169,6 @@ public function edit($request) } else { // If not requested by ajax, we need to render it within the controller context+template return $controller->customise([ - // TODO CMS coupling 'Content' => $return, ]); } @@ -179,10 +178,6 @@ public function edit($request) * Builds an item edit form. The arguments to getCMSFields() are the popupController and * popupFormName, however this is an experimental API and may change. * - * @todo In the future, we will probably need to come up with a tigher object representing a partially - * complete controller with gaps for extra functionality. This, for example, would be a better way - * of letting Security/login put its log-in form inside a UI specified elsewhere. - * * @return Form|HTTPResponse */ public function ItemEditForm() @@ -266,12 +261,10 @@ public function ItemEditForm() $form->loadDataFrom(['ManyMany' => $extraData]); } - // TODO Coupling with CMS $toplevelController = $this->getToplevelController(); if ($toplevelController && $toplevelController instanceof LeftAndMain) { // Always show with base template (full width, no other panels), // regardless of overloaded CMS controller templates. - // TODO Allow customization, e.g. to display an edit form alongside a search form from the CMS controller $form->setTemplate([ 'type' => 'Includes', 'SilverStripe\\Admin\\LeftAndMain_EditForm', @@ -464,7 +457,6 @@ protected function getToplevelController() protected function getBackLink() { - // TODO Coupling with CMS $backlink = ''; $toplevelController = $this->getToplevelController(); if ($toplevelController && $toplevelController instanceof LeftAndMain) { diff --git a/src/Forms/GridField/GridFieldExportButton.php b/src/Forms/GridField/GridFieldExportButton.php index e845e4383d0..d52d9c8219e 100644 --- a/src/Forms/GridField/GridFieldExportButton.php +++ b/src/Forms/GridField/GridFieldExportButton.php @@ -209,7 +209,6 @@ public function generateExportFileData($gridField) $items = $gridField->getManipulatedList(); - // @todo should GridFieldComponents change behaviour based on whether others are available in the config? foreach ($gridField->getConfig()->getComponents() as $component) { if ($component instanceof GridFieldFilterHeader || $component instanceof GridFieldSortableHeader) { $items = $component->getManipulatedData($gridField, $items); diff --git a/src/Forms/GroupedDropdownField.php b/src/Forms/GroupedDropdownField.php index f30d8c5c746..59438ff45dc 100644 --- a/src/Forms/GroupedDropdownField.php +++ b/src/Forms/GroupedDropdownField.php @@ -55,8 +55,6 @@ class GroupedDropdownField extends DropdownField { - // TODO remove this when GroupedDropdownField is implemented - // This should be one of SCHEMA_DATA_TYPE_* constants instead protected $schemaDataType = 'GroupedDropdownField'; /** diff --git a/src/Forms/MoneyField.php b/src/Forms/MoneyField.php index 6f1c231a847..614d7ebf1d6 100644 --- a/src/Forms/MoneyField.php +++ b/src/Forms/MoneyField.php @@ -17,7 +17,6 @@ class MoneyField extends FormField { - // TODO replace with `FormField::SCHEMA_DATA_TYPE_TEXT` when MoneyField is implemented protected $schemaDataType = 'MoneyField'; /** diff --git a/src/Forms/SelectionGroup.php b/src/Forms/SelectionGroup.php index 63dd906ae7e..017905b2192 100644 --- a/src/Forms/SelectionGroup.php +++ b/src/Forms/SelectionGroup.php @@ -90,7 +90,6 @@ public function FieldList() } $itemID = $this->ID() . '_' . (++$count); - // @todo Move into SelectionGroup_Item.ss template at some point. $extra = [ "RadioButton" => DBField::create_field('HTMLFragment', HTML::createTag( 'input', diff --git a/src/Forms/TimeField.php b/src/Forms/TimeField.php index 525f6dfc40b..01d4e99fd05 100644 --- a/src/Forms/TimeField.php +++ b/src/Forms/TimeField.php @@ -14,8 +14,6 @@ * # Localization * * See {@link DateField} - * - * @todo Timezone support */ class TimeField extends TextField { diff --git a/src/Logging/DebugViewFriendlyErrorFormatter.php b/src/Logging/DebugViewFriendlyErrorFormatter.php index 6769c97e4d1..ae16771338e 100644 --- a/src/Logging/DebugViewFriendlyErrorFormatter.php +++ b/src/Logging/DebugViewFriendlyErrorFormatter.php @@ -126,7 +126,6 @@ public function formatBatch(array $records) */ public function output($statusCode) { - // TODO: Refactor into a content-type option if (Director::is_ajax()) { return $this->getTitle(); } diff --git a/src/Logging/HTTPOutputHandler.php b/src/Logging/HTTPOutputHandler.php index 5c2312d0a07..b6d922342ba 100644 --- a/src/Logging/HTTPOutputHandler.php +++ b/src/Logging/HTTPOutputHandler.php @@ -165,8 +165,6 @@ protected function write(LogRecord $record): void } } - // TODO: This coupling isn't ideal - // See https://github.com/silverstripe/silverstripe-framework/issues/4484 if (Controller::has_curr()) { $response = Controller::curr()->getResponse(); } else { diff --git a/src/ORM/Connect/DBConnector.php b/src/ORM/Connect/DBConnector.php index f192d50b08c..5e0413f3f6e 100644 --- a/src/ORM/Connect/DBConnector.php +++ b/src/ORM/Connect/DBConnector.php @@ -37,7 +37,6 @@ abstract class DBConnector * it will be called on the object itself and as such can be overridden in a subclass. * Subclasses should run all errors through this function. * - * @todo hook this into a more well-structured error handling system. * @param string $msg The error message. * @param integer $errorLevel The level of the error to throw. * @param string $sql The SQL related to this query diff --git a/src/ORM/Connect/DBSchemaManager.php b/src/ORM/Connect/DBSchemaManager.php index 6cc5366218c..56a50867f1e 100644 --- a/src/ORM/Connect/DBSchemaManager.php +++ b/src/ORM/Connect/DBSchemaManager.php @@ -350,8 +350,6 @@ protected function transInitTable($table) * Generate the following table in the database, modifying whatever already exists * as necessary. * - * @todo Change detection for CREATE TABLE $options other than "Engine" - * * @param string $table The name of the table * @param array $fieldSchema A list of the fields to create, in the same form as DataObject::$db * @param array $indexSchema A list of indexes to create. See {@link requireIndex()} @@ -669,7 +667,6 @@ public function hasField($tableName, $fieldName) */ public function requireField($table, $field, $spec) { - //TODO: this is starting to get extremely fragmented. //There are two different versions of $spec floating around, and their content changes depending //on how they are structured. This needs to be tidied up. $fieldValue = null; @@ -687,7 +684,6 @@ public function requireField($table, $field, $spec) // Collations didn't come in until MySQL 4.1. Anything earlier will throw a syntax error if you try and use // collations. - // TODO: move this to the MySQLDatabase file, or drop it altogether? if (!$this->database->supportsCollations()) { $spec = preg_replace('/ *character set [^ ]+( collate [^ ]+)?( |$)/', '\\2', $spec ?? ''); } @@ -974,7 +970,6 @@ abstract public function dropDatabase($name); * @param string $tableName The name of the table. * @param string $indexName The name of the index. * @param array $indexSpec The specification of the index, see Database::requireIndex() for more details. - * @todo Find out where this is called from - Is it even used? Aren't indexes always dropped and re-added? */ abstract public function alterIndex($tableName, $indexName, $indexSpec); diff --git a/src/ORM/Connect/Database.php b/src/ORM/Connect/Database.php index bd2084c8c39..2d756f6fde0 100644 --- a/src/ORM/Connect/Database.php +++ b/src/ORM/Connect/Database.php @@ -563,7 +563,6 @@ abstract public function datetimeDifferenceClause($date1, $date2); */ public function concatOperator() { - // @todo Make ' + ' in mssql return ' || '; } @@ -714,7 +713,6 @@ public function withTransaction( * will be an extension name, and the value the configuration for that extension. This * could be one of partitions, tablespaces, or clustering * @return boolean Flag indicating support for all of the above - * @todo Write test cases */ public function supportsExtensions($extensions) { diff --git a/src/ORM/DB.php b/src/ORM/DB.php index c184ddcc302..250a09229a1 100644 --- a/src/ORM/DB.php +++ b/src/ORM/DB.php @@ -471,8 +471,6 @@ public static function prepared_query($sql, $parameters, $errorLevel = E_USER_ER * That's a limitation of the system that's due to it being written for {@link DataObject::write()}, * which needs to do a single write on a number of different tables. * - * @todo Update this to support paramaterised queries - * * @param array $manipulation */ public static function manipulate($manipulation) diff --git a/src/ORM/DataList.php b/src/ORM/DataList.php index 1392933c4bd..edc3c040cf9 100644 --- a/src/ORM/DataList.php +++ b/src/ORM/DataList.php @@ -472,8 +472,6 @@ public function orderBy(string $orderBy): static * E.g. ->filter('Field:not', 'value) will generate '... OR "Field" IS NULL', and * ->filter('Field:not', null) will generate '"Field" IS NOT NULL' * - * @todo extract the sql from $customQuery into a SQLGenerator class - * * @param string|array Escaped SQL statement. If passed as array, all keys and values will be escaped internally * @return $this */ @@ -536,8 +534,6 @@ public function addFilter($filterArray) * $list = $list->filterAny(array('Name'=>array('bob','phil'), 'Age'=>array(21, 43))); * // SQL: WHERE (("Name" IN ('bob', 'phil')) OR ("Age" IN ('21', '43')) * - * @todo extract the sql from this method into a SQLGenerator class - * * @param string|array See {@link filter()} * @return static */ @@ -679,8 +675,6 @@ protected function isValidRelationName($field) * @example $list = $list->exclude(array('Name'=>array('bob','phil'), 'Age'=>array(21, 43))); * // bob age 21 or 43, phil age 21 or 43 would be excluded * - * @todo extract the sql from this method into a SQLGenerator class - * * @param string|array * @param string [optional] * @@ -1817,7 +1811,6 @@ public function add($item) /** * Return a new item to add to this DataList. * - * @todo This doesn't factor in filters. * @param array $initialFields * @return DataObject */ @@ -1831,8 +1824,6 @@ public function newObject($initialFields = null) * Remove this item by deleting it * * @param DataObject $item - * @todo Allow for amendment of this behaviour - for example, we can remove an item from - * an "ActiveItems" DataList by changing the status to inactive. */ public function remove($item) { diff --git a/src/ORM/DataObject.php b/src/ORM/DataObject.php index b0514fc7b47..3e978eb05f0 100644 --- a/src/ORM/DataObject.php +++ b/src/ORM/DataObject.php @@ -99,9 +99,6 @@ * the results are cached in memory through {@link cachedCall()}. * * - * @todo Add instance specific removeExtension() which undos loadExtraStatics() - * and defineMethods() - * * @property int $ID ID of the DataObject, 0 if the DataObject doesn't exist in database. * @property int $OldID ID of object, if deleted * @property string $Title @@ -128,8 +125,6 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity private static $plural_name = null; /** - * Allow API access to this object? - * @todo Define the options that can be set here * @config */ private static $api_access = false; @@ -682,8 +677,6 @@ protected function duplicateBelongsToRelation($sourceObject, $destinationObject, $clonedItem = $item->duplicate(false); $destinationObject->setComponent($relation, $clonedItem); // After $clonedItem is assigned the appropriate FieldID / FieldClass, force write - // @todo Write this component in onAfterWrite instead, assigning the FieldID then - // https://github.com/silverstripe/silverstripe-framework/issues/7818 $clonedItem->write(); } @@ -1151,7 +1144,6 @@ public function merge($rightObj, $priority = 'right', $includeRelations = true, continue; } - // TODO remove redundant merge of has_one fields $leftObj->{$key} = $rightObj->{$key}; } @@ -1752,10 +1744,6 @@ public function delete() throw new LogicException("DataObject::delete() called on a DataObject without an ID"); } - // TODO: This is quite ugly. To improve: - // - move the details of the delete code in the DataQuery system - // - update the code to just delete the base table, and rely on cascading deletes in the DB to do the rest - // obviously, that means getting requireTable() to configure cascading deletes ;-) $srcQuery = DataList::create(static::class) ->filter('ID', $this->ID) ->dataQuery() @@ -1908,8 +1896,6 @@ public function setComponent($componentName, $item) $schema = static::getSchema(); if ($class = $schema->hasOneComponent(static::class, $componentName)) { // Force item to be written if not by this point - // @todo This could be lazy-written in a beforeWrite hook, but force write here for simplicity - // https://github.com/silverstripe/silverstripe-framework/issues/7818 if ($item && !$item->isInDB()) { $item->write(); } @@ -2594,8 +2580,6 @@ public function getCMSCompositeValidator(): CompositeValidator * by default. To customize, either overload this method in your * subclass, or extend it by {@link DataExtension->updateFrontEndFields()}. * - * @todo Decide on naming for "website|frontend|site|page" and stick with it in the API - * * @param array $params See {@link scaffoldFormFields()} * @return FieldList Always returns a simple field collection without TabSet. */ @@ -2692,7 +2676,6 @@ protected function loadLazyFields($class = null) $columns = []; // Add SQL for fields, both simple & multi-value - // TODO: This is copy & pasted from buildSQL(), it could be moved into a method $databaseFields = $schema->databaseFields($class, false); foreach ($databaseFields as $k => $v) { if (!isset($this->record[$k]) || $this->record[$k] === null) { @@ -2771,7 +2754,6 @@ public function getChangedFields($databaseFieldsOnly = false, $changeLevel = sel array_keys($this->record ?? []), array_fill(0, count($this->record ?? []), self::CHANGE_STRICT) ); - // @todo Find better way to allow versioned to write a new version after forceChange unset($changed['Version']); } else { $changed = $this->changed; @@ -2905,8 +2887,6 @@ private function setFieldValue(string $fieldName, mixed $val): void // if a field is not existing or has strictly changed if (!array_key_exists($fieldName, $this->original ?? []) || $this->original[$fieldName] !== $val) { - // TODO Add check for php-level defaults which are not set in the db - // TODO Add check for hidden input-fields (readonly) which are not set in the db // At the very least, the type has changed $this->changed[$fieldName] = self::CHANGE_STRICT; @@ -3314,8 +3294,6 @@ public function getReverseAssociation($className) * @param string|array $limit A limit expression to be inserted into the LIMIT clause. * @param string $containerClass The container class to return the results in. * - * @todo $containerClass is Ignored, why? - * * @return DataList The objects matching the filter, in the class specified by $containerClass */ public static function get( @@ -3480,7 +3458,6 @@ public static function flush_and_destroy_cache() */ public static function reset() { - // @todo Decouple these DBEnum::flushCache(); ClassInfo::reset_db_cache(); static::getSchema()->reset(); @@ -3941,8 +3918,6 @@ public function fieldLabel($name) /** * Get the default summary fields for this object. * - * @todo use the translation apparatus to return a default field selection for the language - * * @return array */ public function summaryFields() @@ -4000,8 +3975,6 @@ public function summaryFields() * it is constructed here. Otherwise, the default filter specified in * {@link DBField} is used. * - * @todo error handling/type checking for valid FormField and SearchFilter subclasses? - * * @return array */ public function defaultSearchFilters() diff --git a/src/ORM/DataObjectSchema.php b/src/ORM/DataObjectSchema.php index dcd7ca17d7a..09e15149aac 100644 --- a/src/ORM/DataObjectSchema.php +++ b/src/ORM/DataObjectSchema.php @@ -1153,7 +1153,7 @@ protected function checkManyManyFieldClass($parentClass, $component, $joinClass, if ($key === 'from') { return $relationClass; } - // @todo support polymorphic 'to' + throw new InvalidArgumentException( "many_many through relation {$parentClass}.{$component} {$key} references a polymorphic field " . "{$joinClass}::{$relation} which is not supported" diff --git a/src/ORM/DataQuery.php b/src/ORM/DataQuery.php index 2b41c51c4c0..303117066a4 100644 --- a/src/ORM/DataQuery.php +++ b/src/ORM/DataQuery.php @@ -63,9 +63,8 @@ class DataQuery */ private $queryFinalised = false; - // TODO: replace subclass_access with this protected $querySubclasses = true; - // TODO: replace restrictclasses with this + protected $filterByClassName = true; /** @@ -335,9 +334,6 @@ public function getFinalisedQuery($queriedColumns = null) "RecordClassName" ); - // TODO: Versioned, SiteTreeSubsites, etc, could probably be better implemented as subclasses - // of DataQuery - $obj = Injector::inst()->get($this->dataClass); $obj->extend('augmentSQL', $query, $this); diff --git a/src/ORM/DatabaseAdmin.php b/src/ORM/DatabaseAdmin.php index 698fe6d3fe2..c82e3d377b9 100644 --- a/src/ORM/DatabaseAdmin.php +++ b/src/ORM/DatabaseAdmin.php @@ -519,8 +519,6 @@ public function cleanup() /** * Migrate all class names - * - * @todo Migrate to separate build task */ protected function migrateClassNames() { diff --git a/src/ORM/FieldType/DBComposite.php b/src/ORM/FieldType/DBComposite.php index 2447f3df952..c560a6098b2 100644 --- a/src/ORM/FieldType/DBComposite.php +++ b/src/ORM/FieldType/DBComposite.php @@ -12,8 +12,6 @@ * Extend this class when designing a {@link DBField} that doesn't have a 1-1 mapping with a database field. * This includes multi-value fields and transformed fields * - * @todo Unittests for loading and saving composite values (see GIS module for existing similar unittests) - * * Example with a combined street name and number: * * class Street extends DBComposite { diff --git a/src/ORM/FieldType/DBDatetime.php b/src/ORM/FieldType/DBDatetime.php index 8668018a3de..ca3c49e7a7b 100644 --- a/src/ORM/FieldType/DBDatetime.php +++ b/src/ORM/FieldType/DBDatetime.php @@ -30,7 +30,6 @@ * ); * * - * @todo Add localization support, see http://open.silverstripe.com/ticket/2931 */ class DBDatetime extends DBDate implements TemplateGlobalProvider { diff --git a/src/ORM/FieldType/DBDouble.php b/src/ORM/FieldType/DBDouble.php index ad53e02a992..04b91eab5ae 100644 --- a/src/ORM/FieldType/DBDouble.php +++ b/src/ORM/FieldType/DBDouble.php @@ -14,7 +14,6 @@ class DBDouble extends DBFloat public function requireField() { // HACK: MSSQL does not support double so we're using float instead - // @todo This should go into MSSQLDatabase ideally somehow if (DB::get_conn() instanceof MySQLDatabase) { DB::require_field($this->tableName, $this->name, "double"); } else { diff --git a/src/ORM/FieldType/DBField.php b/src/ORM/FieldType/DBField.php index 520ce73d851..079df6b8faf 100644 --- a/src/ORM/FieldType/DBField.php +++ b/src/ORM/FieldType/DBField.php @@ -41,8 +41,6 @@ * } * } * - * - * @todo remove MySQL specific code from subclasses */ abstract class DBField extends ViewableData implements DBIndexable { @@ -579,12 +577,6 @@ public function scaffoldSearchField($title = null) } /** - * @todo documentation - * - * @todo figure out how we pass configuration parameters to - * search filters (note: parameter hack now in place to pass in the required full path - using $this->name - * won't work) - * * @param string $name Override name of this field * @return SearchFilter */ diff --git a/src/ORM/FieldType/DBLocale.php b/src/ORM/FieldType/DBLocale.php index fbd94751285..9b5e7c61458 100644 --- a/src/ORM/FieldType/DBLocale.php +++ b/src/ORM/FieldType/DBLocale.php @@ -6,8 +6,6 @@ /** * Locale database field - * - * @todo Allowing showing locale values in different languages through Nice() */ class DBLocale extends DBVarchar { diff --git a/src/ORM/FieldType/DBMultiEnum.php b/src/ORM/FieldType/DBMultiEnum.php index 127e54ee00d..93cccab8e4e 100644 --- a/src/ORM/FieldType/DBMultiEnum.php +++ b/src/ORM/FieldType/DBMultiEnum.php @@ -35,7 +35,6 @@ public function __construct($name = null, $enum = null, $default = null) public function requireField() { - // @todo: Remove mysql-centric logic from this $charset = Config::inst()->get(MySQLDatabase::class, 'charset'); $collation = Config::inst()->get(MySQLDatabase::class, 'collation'); $values = [ diff --git a/src/ORM/FieldType/DBPolymorphicForeignKey.php b/src/ORM/FieldType/DBPolymorphicForeignKey.php index a2c680c5c78..a70be359cc7 100644 --- a/src/ORM/FieldType/DBPolymorphicForeignKey.php +++ b/src/ORM/FieldType/DBPolymorphicForeignKey.php @@ -18,9 +18,8 @@ class DBPolymorphicForeignKey extends DBComposite public function scaffoldFormField($title = null, $params = null) { - // Opt-out of form field generation - Scaffolding should be performed on + // Don't provide scaffolded form field generation - Scaffolding should be performed on // the has_many end, or set programmatically. - // @todo - Investigate suitable FormField return null; } diff --git a/src/ORM/FieldType/DBPrimaryKey.php b/src/ORM/FieldType/DBPrimaryKey.php index 8132bfa3f91..7e9a207e240 100644 --- a/src/ORM/FieldType/DBPrimaryKey.php +++ b/src/ORM/FieldType/DBPrimaryKey.php @@ -7,8 +7,6 @@ /** * A special type Int field used for primary keys. - * - * @todo Allow for custom limiting/filtering of scaffoldFormField dropdown */ class DBPrimaryKey extends DBInt { diff --git a/src/ORM/Filters/ExactMatchFilter.php b/src/ORM/Filters/ExactMatchFilter.php index 5f4d1dfc3e2..07701843430 100644 --- a/src/ORM/Filters/ExactMatchFilter.php +++ b/src/ORM/Filters/ExactMatchFilter.php @@ -13,7 +13,6 @@ /** * Selects textual content with an exact match between columnname and keyword. * - * @todo documentation */ class ExactMatchFilter extends SearchFilter { diff --git a/src/ORM/Filters/FulltextFilter.php b/src/ORM/Filters/FulltextFilter.php index d49b559dd13..d0de1f8ca88 100755 --- a/src/ORM/Filters/FulltextFilter.php +++ b/src/ORM/Filters/FulltextFilter.php @@ -25,7 +25,6 @@ * ]; * * - * @todo Add support for databases besides MySQL */ class FulltextFilter extends SearchFilter { diff --git a/src/ORM/Filters/SearchFilter.php b/src/ORM/Filters/SearchFilter.php index 204a11159df..daf06f987fd 100644 --- a/src/ORM/Filters/SearchFilter.php +++ b/src/ORM/Filters/SearchFilter.php @@ -332,7 +332,6 @@ public function getDbName() public function getDbFormattedValue() { // SRM: This code finds the table where the field named $this->name lives - // Todo: move to somewhere more appropriate, such as DataMapper, the magical class-to-be? if ($this->aggregate) { return intval($this->value); diff --git a/src/ORM/Filters/WithinRangeFilter.php b/src/ORM/Filters/WithinRangeFilter.php index 8d3da459239..55f943e334c 100644 --- a/src/ORM/Filters/WithinRangeFilter.php +++ b/src/ORM/Filters/WithinRangeFilter.php @@ -4,11 +4,6 @@ use SilverStripe\ORM\DataQuery; -/** - * Incomplete. - * - * @todo add to tests - */ class WithinRangeFilter extends SearchFilter { diff --git a/src/ORM/HasManyList.php b/src/ORM/HasManyList.php index 2837ccdf6a6..a28abfadb79 100644 --- a/src/ORM/HasManyList.php +++ b/src/ORM/HasManyList.php @@ -119,7 +119,6 @@ public function removeByID($itemID) * Doesn't actually remove the item, it just clears the foreign key value. * * @param DataObject $item The DataObject to be removed - * @todo Maybe we should delete the object instead? */ public function remove($item) { diff --git a/src/ORM/PolymorphicHasManyList.php b/src/ORM/PolymorphicHasManyList.php index 20f9907c19c..499d8e00355 100644 --- a/src/ORM/PolymorphicHasManyList.php +++ b/src/ORM/PolymorphicHasManyList.php @@ -111,7 +111,6 @@ public function add($item) * Doesn't actually remove the item, it just clears the foreign key value. * * @param DataObject $item The DataObject to be removed - * @todo Maybe we should delete the object instead? */ public function remove($item) { diff --git a/src/ORM/Queries/SQLAssignmentRow.php b/src/ORM/Queries/SQLAssignmentRow.php index bf4bd9c5bda..17a1a51d574 100644 --- a/src/ORM/Queries/SQLAssignmentRow.php +++ b/src/ORM/Queries/SQLAssignmentRow.php @@ -68,8 +68,6 @@ protected function parseAssignment($value) $parameters = [$parameters]; } - // @todo Some input sanitisation checking the key contains the - // correct number of ? placeholders as the number of parameters return [$sql => $parameters]; } } diff --git a/src/ORM/Queries/SQLConditionalExpression.php b/src/ORM/Queries/SQLConditionalExpression.php index 55d6ae5c297..55aef214aed 100644 --- a/src/ORM/Queries/SQLConditionalExpression.php +++ b/src/ORM/Queries/SQLConditionalExpression.php @@ -256,8 +256,6 @@ public function getFrom() /** * Retrieves the finalized list of joins * - * @todo This part of the code could be simplified - * * @param array $parameters Out variable for parameters required for this query * @return array List of joins as a mapping from array('Alias' => 'Join Expression') */ @@ -693,8 +691,6 @@ public function splitQueryParameters($conditions, &$predicates, &$parameters) /** * Checks whether this query is for a specific ID in a table * - * @todo Doesn't work with combined statements (e.g. "Foo='bar' AND ID=5") - * * @return boolean */ public function filtersOnID() @@ -713,15 +709,12 @@ public function filtersOnID() /** * Checks whether this query is filtering on a foreign key, ie finding a has_many relationship * - * @todo Doesn't work with combined statements (e.g. "Foo='bar' AND ParentID=5") - * * @return boolean */ public function filtersOnFK() { $regexp = '/^(.*\.)?("|`)?[a-zA-Z]+ID("|`)?\s?(=|IN)/'; - // @todo - Test this works with parameterized queries foreach ($this->getWhereParameterised($parameters) as $predicate) { if (preg_match($regexp ?? '', $predicate ?? '')) { return true; diff --git a/src/ORM/Queries/SQLExpression.php b/src/ORM/Queries/SQLExpression.php index f7e261726cc..168f943d8c5 100644 --- a/src/ORM/Queries/SQLExpression.php +++ b/src/ORM/Queries/SQLExpression.php @@ -45,8 +45,6 @@ public function replaceText($old, $new) /** * Return the generated SQL string for this query * - * @todo Is it ok for this to consider parameters? Test cases here! - * * @return string */ public function __toString() diff --git a/src/ORM/Queries/SQLSelect.php b/src/ORM/Queries/SQLSelect.php index fa38005aaf3..c016b77ef3d 100644 --- a/src/ORM/Queries/SQLSelect.php +++ b/src/ORM/Queries/SQLSelect.php @@ -575,7 +575,6 @@ public function unlimitedRowCount($column = null) // Choose a default column if ($column == null) { if ($this->groupby) { - // @todo Test case required here $countQuery = new SQLSelect(); $countQuery->setSelect("count(*)"); $countQuery->setFrom(['(' . $clone->sql($innerParameters) . ') all_distinct']); diff --git a/src/ORM/Search/SearchContext.php b/src/ORM/Search/SearchContext.php index 535af6bcb3c..978ba3677e0 100644 --- a/src/ORM/Search/SearchContext.php +++ b/src/ORM/Search/SearchContext.php @@ -107,10 +107,6 @@ public function getSearchFields() return ($this->fields) ? $this->fields : singleton($this->modelClass)->scaffoldSearchFields(); } - /** - * @todo move to SQLSelect - * @todo fix hack - */ protected function applyBaseTableFields() { $classes = ClassInfo::dataClassesFor($this->modelClass); @@ -327,8 +323,6 @@ private function applyFilter(SearchFilter $filter, DataQuery $dataQuery, array $ /** * Returns a result set from the given search parameters. * - * @todo rearrange start and limit params to reflect DataObject - * * @param array $searchParams * @param array|bool|string $sort * @param array|null|string $limit diff --git a/src/Security/Group.php b/src/Security/Group.php index 502a1fea307..7bf3ed7c9c4 100755 --- a/src/Security/Group.php +++ b/src/Security/Group.php @@ -183,8 +183,6 @@ public function getCMSFields() if ($record && !$record->ID) { $groupsField->setValue($group->ID); } elseif ($record && $record->ID) { - // TODO Mark disabled once chosen.js supports it - // $groupsField->setDisabledItems(array($group->ID)); $form->Fields()->replaceField( 'DirectGroups', $groupsField->performReadonlyTransformation() @@ -194,8 +192,6 @@ public function getCMSFields() }); $memberList = GridField::create('Members', false, $this->DirectMembers(), $config) ->addExtraClass('members_grid'); - // @todo Implement permission checking on GridField - //$memberList->setPermissions(array('edit', 'delete', 'export', 'add', 'inlineadd')); $fields->addFieldToTab('Root.Members', $memberList); } @@ -238,8 +234,6 @@ class_exists(SecurityAdmin::class) sprintf( '%s', SecurityAdmin::singleton()->Link('show/root#Root_Roles'), - // TODO This should include #Root_Roles to switch directly to the tab, - // but tabstrip.js doesn't display tabs when directly addressed through a URL pragma _t('SilverStripe\\Security\\Group.RolesAddEditLink', 'Manage roles') ) . "

" diff --git a/src/Security/GroupCsvBulkLoader.php b/src/Security/GroupCsvBulkLoader.php index 40db7d46937..64bc8079c47 100644 --- a/src/Security/GroupCsvBulkLoader.php +++ b/src/Security/GroupCsvBulkLoader.php @@ -5,9 +5,6 @@ use SilverStripe\Dev\CsvBulkLoader; use SilverStripe\ORM\DataObject; -/** - * @todo Migrate Permission->Arg and Permission->Type values - */ class GroupCsvBulkLoader extends CsvBulkLoader { diff --git a/src/Security/Member.php b/src/Security/Member.php index 2dffce485e2..dc309b0da7a 100644 --- a/src/Security/Member.php +++ b/src/Security/Member.php @@ -114,9 +114,6 @@ class Member extends DataObject * statement. * * @var array - * @todo Generic implementation of $searchable_fields on DataObject, - * with definition for different searching algorithms - * (LIKE, FULLTEXT) and default FormFields to construct a searchform. */ private static $searchable_fields = [ 'FirstName', @@ -446,7 +443,6 @@ public function isPasswordExpired(): bool */ public function beforeMemberLoggedIn() { - // @todo Move to middleware on the AuthenticationMiddleware IdentityStore $this->extend('beforeMemberLoggedIn'); } @@ -619,7 +615,6 @@ public static function member_from_tempid($tempid) * Returns the fields for the member form - used in the registration/profile module. * It should return fields that are editable by the admin and the logged-in user. * - * @todo possibly move this to an extension * * @return FieldList Returns a {@link FieldList} containing the fields for * the member form. @@ -770,7 +765,6 @@ public function onBeforeWrite() // We don't send emails out on dev/tests sites to prevent accidentally spamming users. // However, if TestMailer is in use this isn't a risk. - // @todo some developers use external tools, so emailing might be a good idea anyway if ((Director::isLive() || Injector::inst()->get(MailerInterface::class) instanceof TestMailer) && $this->isChanged('Password') && $this->record['Password'] @@ -1151,7 +1145,6 @@ public function getTimeFormat() * including any parent groups where membership is implied. * Use {@link DirectGroups()} to only retrieve the group relations without inheritance. * - * @todo Push all this logic into Member_GroupSet's getIterator()? * @return Member_Groupset */ public function Groups() diff --git a/src/Security/MemberAuthenticator/ChangePasswordHandler.php b/src/Security/MemberAuthenticator/ChangePasswordHandler.php index 43cc600fa4d..b2330f5b23f 100644 --- a/src/Security/MemberAuthenticator/ChangePasswordHandler.php +++ b/src/Security/MemberAuthenticator/ChangePasswordHandler.php @@ -58,7 +58,6 @@ public function __construct($link, MemberAuthenticator $authenticator) /** * Handle the change password request - * @todo this could use some spring cleaning * * @return array|HTTPResponse */ diff --git a/src/Security/MemberAuthenticator/CookieAuthenticationHandler.php b/src/Security/MemberAuthenticator/CookieAuthenticationHandler.php index 54f710de671..677de47108b 100644 --- a/src/Security/MemberAuthenticator/CookieAuthenticationHandler.php +++ b/src/Security/MemberAuthenticator/CookieAuthenticationHandler.php @@ -173,13 +173,9 @@ public function authenticateRequest(HTTPRequest $request) } if ($this->cascadeInTo) { - // @todo look at how to block "regular login" triggers from happening here - // @todo deal with the fact that the Session::current_session() isn't correct here :-/ $this->cascadeInTo->logIn($member, false, $request); } - // @todo Consider whether response should be part of logIn() as well - // Renew the token $rememberLoginHash->renew(); $tokenExpiryDays = RememberLoginHash::config()->uninherited('token_expiry_days'); diff --git a/src/Security/MemberAuthenticator/MemberAuthenticator.php b/src/Security/MemberAuthenticator/MemberAuthenticator.php index 755d83c8de8..6c2d83ecbf5 100644 --- a/src/Security/MemberAuthenticator/MemberAuthenticator.php +++ b/src/Security/MemberAuthenticator/MemberAuthenticator.php @@ -168,7 +168,6 @@ public function checkPassword(Member $member, $password, ValidationResult &$resu /** * Log login attempt - * TODO We could handle this with an extension * * @param array $data * @param HTTPRequest $request diff --git a/src/Security/MemberAuthenticator/MemberLoginForm.php b/src/Security/MemberAuthenticator/MemberLoginForm.php index 1a31e55a236..94dd5027d1c 100644 --- a/src/Security/MemberAuthenticator/MemberLoginForm.php +++ b/src/Security/MemberAuthenticator/MemberLoginForm.php @@ -84,7 +84,6 @@ public function __construct( } if ($checkCurrentUser && Security::getCurrentUser()) { - // @todo find a more elegant way to handle this $logoutAction = Security::logout_url(); $fields = FieldList::create( HiddenField::create('AuthenticationMethod', null, $this->getAuthenticatorClass(), $this) @@ -134,7 +133,6 @@ protected function getFormFields() HiddenField::create("AuthenticationMethod", null, $this->getAuthenticatorClass(), $this), // Regardless of what the unique identifier field is (usually 'Email'), it will be held in the // 'Email' value, below: - // @todo Rename the field to a more generic covering name $emailField = TextField::create("Email", $label, null, null, $this), PasswordField::create("Password", _t('SilverStripe\\Security\\Member.PASSWORD', 'Password')) ); diff --git a/src/Security/MemberAuthenticator/SessionAuthenticationHandler.php b/src/Security/MemberAuthenticator/SessionAuthenticationHandler.php index 8036f603913..5dec89702a3 100644 --- a/src/Security/MemberAuthenticator/SessionAuthenticationHandler.php +++ b/src/Security/MemberAuthenticator/SessionAuthenticationHandler.php @@ -80,7 +80,6 @@ public function logIn(Member $member, $persistent = false, HTTPRequest $request $session->set($this->getSessionVariable(), $member->ID); // This lets apache rules detect whether the user has logged in - // @todo make this a setting on the authentication handler if (Member::config()->get('login_marker_cookie')) { Cookie::set(Member::config()->get('login_marker_cookie'), 1, 0); } @@ -109,7 +108,6 @@ protected static function regenerateSessionId() $file = ''; $line = ''; - // TODO: deprecate and use Session::regenerateSessionId // @ is to suppress win32 warnings/notices when session wasn't cleaned up properly // There's nothing we can do about this, because it's an operating system function! if (!headers_sent($file, $line)) { diff --git a/src/Security/MemberCsvBulkLoader.php b/src/Security/MemberCsvBulkLoader.php index 35c255d6a43..cde99eb9713 100644 --- a/src/Security/MemberCsvBulkLoader.php +++ b/src/Security/MemberCsvBulkLoader.php @@ -45,7 +45,6 @@ public function processRecord($record, $columnMap, &$results, $preview = false) /** @var Member $member */ $member = DataObject::get_by_id($this->objectClass, $objID); foreach ($this->groups as $group) { - // TODO This isnt the most memory effective way to add members to a group $member->Groups()->add($group); } diff --git a/src/Security/Permission.php b/src/Security/Permission.php index 8e1dad98f95..c15757f575a 100644 --- a/src/Security/Permission.php +++ b/src/Security/Permission.php @@ -133,7 +133,6 @@ public static function check($code, $arg = "any", $member = null, $strict = true /** * Flush the permission cache, for example if you have edited group membership or a permission record. - * @todo Call this whenever Group_Members is added to or removed from */ public static function reset() { diff --git a/src/Security/Security.php b/src/Security/Security.php index 215059772d9..82bfb5bc888 100644 --- a/src/Security/Security.php +++ b/src/Security/Security.php @@ -416,7 +416,6 @@ public static function permissionFailure($controller = null, $messageSet = null) $request->getSession()->set("BackURL", $_SERVER['REQUEST_URI']); } - // TODO AccessLogEntry needs an extension to handle permission denied errors // Audit logging hook $controller->extend('permissionDenied', $member); diff --git a/src/Security/SecurityToken.php b/src/Security/SecurityToken.php index f54eb6c5dee..e6ba9c2f0e9 100644 --- a/src/Security/SecurityToken.php +++ b/src/Security/SecurityToken.php @@ -35,7 +35,6 @@ * } * * - * @todo Make token name form specific for additional forgery protection. */ class SecurityToken implements TemplateGlobalProvider { diff --git a/src/View/SSTemplateParser.php b/src/View/SSTemplateParser.php index d1778c49b0b..db9f0a6f342 100644 --- a/src/View/SSTemplateParser.php +++ b/src/View/SSTemplateParser.php @@ -1886,8 +1886,6 @@ function PresenceCheck_Argument(&$res, $sub) $res['php'] .= '((bool)'.$sub['php'].')'; } else { $php = ($sub['ArgumentMode'] == 'default' ? $sub['lookup_php'] : $sub['php']); - // TODO: kinda hacky - maybe we need a way to pass state down the parse chain so - // Lookup_LastLookupStep and Argument_BareWord can produce hasValue instead of XML_val $res['php'] .= str_replace('$$FINAL', 'hasValue', $php ?? ''); } } @@ -5292,8 +5290,6 @@ function Text__finalise(&$res) $text = stripslashes($text ?? ''); $text = addcslashes($text ?? '', '\'\\'); - // TODO: This is pretty ugly & gets applied on all files not just html. I wonder if we can make this - // non-dynamically calculated $code = <<<'EOC' (\SilverStripe\View\SSViewer::getRewriteHashLinksDefault() ? \SilverStripe\Core\Convert::raw2att( preg_replace("/^(\\/)+/", "/", $_SERVER['REQUEST_URI'] ) ) @@ -5332,8 +5328,7 @@ public function compileString($string, $templateName = "", $includeDebuggingComm $this->includeDebuggingComments = $includeDebuggingComments; - // Ignore UTF8 BOM at beginning of string. TODO: Confirm this is needed, make sure SSViewer handles UTF - // (and other encodings) properly + // Ignore UTF8 BOM at beginning of string. if (substr($string ?? '', 0, 3) == pack("CCC", 0xef, 0xbb, 0xbf)) { $this->pos = 3; } diff --git a/src/View/ViewableData.php b/src/View/ViewableData.php index 7c3d3f814b0..31f621b5e58 100644 --- a/src/View/ViewableData.php +++ b/src/View/ViewableData.php @@ -438,8 +438,6 @@ public function escapeTypeForField($field) { $class = $this->castingClass($field) ?: $this->config()->get('default_cast'); - // TODO: It would be quicker not to instantiate the object, but to merely - // get its class from the Injector /** @var DBField $type */ $type = Injector::inst()->get($class, true); return $type->config()->get('escape_type'); diff --git a/src/i18n/TextCollection/i18nTextCollector.php b/src/i18n/TextCollection/i18nTextCollector.php index 145f93b0ff8..fce88716dea 100644 --- a/src/i18n/TextCollection/i18nTextCollector.php +++ b/src/i18n/TextCollection/i18nTextCollector.php @@ -71,8 +71,6 @@ class i18nTextCollector * The directory base on which the collector should act. * Usually the webroot set through {@link Director::baseFolder()}. * - * @todo Fully support changing of basePath through {@link SSViewer} and {@link ManifestBuilder} - * * @var string */ public $basePath; @@ -314,9 +312,6 @@ protected function getBestModuleForKey($entitiesByModule, $key) return $owner; } - // @todo - How to determine ownership of templates? Templates can - // exist in multiple locations with the same name. - // Display notice if not found Debug::message( "Duplicate key {$key} detected in no / multiple modules with no obvious owner", diff --git a/tests/behat/src/CmsFormsContext.php b/tests/behat/src/CmsFormsContext.php index df9ae575d5c..3c471fcbfa1 100644 --- a/tests/behat/src/CmsFormsContext.php +++ b/tests/behat/src/CmsFormsContext.php @@ -137,7 +137,6 @@ public function theHtmlFieldShouldContain($locator, $negative, $html) * Example: Given "my text" in the "Content" HTML field should be right aligned * Example: Given "my text" in the "Content" HTML field should not be bold * - * @todo Use an actual DOM parser for more accurate assertions * * @Given /^"(?P([^"]*))" in the "(?P(?:[^"]|\\")*)" HTML field should(?P(?: not)?) be (?P(.*))$/ */ @@ -194,8 +193,7 @@ public function stepIHighlightTextInHtmlField($text, $field) $text = addcslashes($text ?? '', "'"); $js = <<getSession()->switchToIFrame('cms-preview-iframe'); $link = $this->fixStepArgument($link); $this->getSession()->getPage()->clickLink($link); diff --git a/tests/php/Control/DirectorTest.php b/tests/php/Control/DirectorTest.php index a9e417ec98c..f0332322e73 100644 --- a/tests/php/Control/DirectorTest.php +++ b/tests/php/Control/DirectorTest.php @@ -18,9 +18,6 @@ use SilverStripe\Core\Kernel; use SilverStripe\Dev\SapphireTest; -/** - * @todo test Director::alternateBaseFolder() - */ class DirectorTest extends SapphireTest { protected static $extra_controllers = [ diff --git a/tests/php/Control/SessionTest.php b/tests/php/Control/SessionTest.php index e0b4d4c4943..3cae007145f 100644 --- a/tests/php/Control/SessionTest.php +++ b/tests/php/Control/SessionTest.php @@ -133,9 +133,6 @@ public function testStartErrorsWhenStartingTwice() public function testStartRetainsInMemoryData() { $this->markTestIncomplete('Test'); - // TODO Figure out how to simulate session vars without a session_start() resetting them - // $_SESSION['existing'] = true; - // $_SESSION['merge'] = 1; $req = new HTTPRequest('GET', '/'); $session = new Session(null); // unstarted session $session->set('new', true); diff --git a/tests/php/Core/ConvertTest.php b/tests/php/Core/ConvertTest.php index 243694beec0..a4d0d73d055 100644 --- a/tests/php/Core/ConvertTest.php +++ b/tests/php/Core/ConvertTest.php @@ -214,8 +214,6 @@ public function testXml2Raw() /** * Tests {@link Convert::testRaw2URL()} - * - * @todo test toASCII() */ public function testRaw2URL() { diff --git a/tests/php/Core/Manifest/ThemeResourceLoaderTest.php b/tests/php/Core/Manifest/ThemeResourceLoaderTest.php index e02761b50e6..0c4c424f710 100644 --- a/tests/php/Core/Manifest/ThemeResourceLoaderTest.php +++ b/tests/php/Core/Manifest/ThemeResourceLoaderTest.php @@ -213,7 +213,6 @@ public function testFindTemplatesInTheme() */ public function testFindTemplatesInApplication() { - // TODO: replace with one that doesn't create temporary files (so bad) $templates = [ $this->base . '/myproject/templates/Page.ss', $this->base . '/myproject/templates/Layout/Page.ss' diff --git a/tests/php/Core/ObjectTest.php b/tests/php/Core/ObjectTest.php index bf110758655..32dfaa2fd8e 100644 --- a/tests/php/Core/ObjectTest.php +++ b/tests/php/Core/ObjectTest.php @@ -22,11 +22,6 @@ use SilverStripe\Dev\SapphireTest; use SilverStripe\Versioned\Versioned; -/** - * @todo tests for addStaticVars() - * @todo tests for setting statics which are not defined on the object as built-in PHP statics - * @todo tests for setting statics through extensions (#2387) - */ class ObjectTest extends SapphireTest { @@ -253,8 +248,6 @@ public function testHasAndAddExtension() "Injected sub-extensions are detected with static has_extension() when added through add_extension()" ); - // @todo At the moment, this does NOT remove the extension due to parameterized naming, - // meaning the extension will remain added in further test cases ExtensionTest::remove_extension(ExtendTest3::class); } diff --git a/tests/php/Core/PhpSyntaxTest.php b/tests/php/Core/PhpSyntaxTest.php index 77ce2c942ea..53134479d00 100644 --- a/tests/php/Core/PhpSyntaxTest.php +++ b/tests/php/Core/PhpSyntaxTest.php @@ -18,7 +18,6 @@ protected function setUp(): void public function testShortTagsOffWillWork() { // Ignore this test completely if running the test suite on windows - // TODO: Make it work on all platforms, by building an alternative to find | grep. $returnCode = 0; $output = []; exec("which find && which grep && which php", $output, $returnCode); @@ -51,7 +50,6 @@ public function testShortTagsOffWillWork() public function getAllFiles($ext = 'php') { - // TODO: Unix only $cmd = sprintf( 'find %s | grep %s', BASE_PATH, diff --git a/tests/php/Dev/CsvBulkLoaderTest.php b/tests/php/Dev/CsvBulkLoaderTest.php index c6c65e5e089..93388fbf4a3 100644 --- a/tests/php/Dev/CsvBulkLoaderTest.php +++ b/tests/php/Dev/CsvBulkLoaderTest.php @@ -227,8 +227,6 @@ public function testLoadWithCustomHeaderAndRelation() /** * Test import with custom identifiers by importing the data. - * - * @todo Test duplicateCheck callbacks */ public function testLoadWithIdentifiers() { diff --git a/tests/php/Forms/CurrencyFieldDisabledTest.php b/tests/php/Forms/CurrencyFieldDisabledTest.php index d02e1375aa0..ed9c8c5ac65 100644 --- a/tests/php/Forms/CurrencyFieldDisabledTest.php +++ b/tests/php/Forms/CurrencyFieldDisabledTest.php @@ -18,9 +18,6 @@ public function testFieldWithValue() $this->assertStringContainsString('$5.00', $result, 'The value should be rendered'); } - /** - * @todo: Update the expectation when intl for currencies is implemented - */ public function testFieldWithCustomisedCurrencySymbol() { DBCurrency::config()->set('currency_symbol', '€'); diff --git a/tests/php/Forms/CurrencyFieldReadonlyTest.php b/tests/php/Forms/CurrencyFieldReadonlyTest.php index 352b97f82c7..7850a79f550 100644 --- a/tests/php/Forms/CurrencyFieldReadonlyTest.php +++ b/tests/php/Forms/CurrencyFieldReadonlyTest.php @@ -37,9 +37,6 @@ public function testFieldWithOutValue() $this->assertStringContainsString('AUD0.00', $result, 'The value should be rendered'); } - /** - * @todo: Update the expectation when intl for currencies is implemented - */ public function testFieldWithCustomisedCurrencySymbol() { DBCurrency::config()->set('currency_symbol', '€'); diff --git a/tests/php/Forms/EmailFieldTest.php b/tests/php/Forms/EmailFieldTest.php index 3ec5a7acd56..26723e555ad 100644 --- a/tests/php/Forms/EmailFieldTest.php +++ b/tests/php/Forms/EmailFieldTest.php @@ -18,8 +18,6 @@ class EmailFieldTest extends FunctionalTest /** * Check the php validator for email addresses. We should be checking against RFC 5322 which defines email address * syntax. - * - * @TODO * - double quotes around the local part (before @) is not supported * - special chars ! # $ % & ' * + - / = ? ^ _ ` { | } ~ are all valid in local part * - special chars ()[]\;:,<> are valid in the local part if the local part is in double quotes diff --git a/tests/php/Forms/FieldListTest.php b/tests/php/Forms/FieldListTest.php index 2718aaaf048..ec235dfeef3 100644 --- a/tests/php/Forms/FieldListTest.php +++ b/tests/php/Forms/FieldListTest.php @@ -20,17 +20,6 @@ /** * Tests for FieldList - * - * @todo test for {@link FieldList->setValues()}. Need to check - * that the values that were set are the correct ones given back. - * @todo test for {@link FieldList->transform()} and {@link FieldList->makeReadonly()}. - * Need to ensure that it correctly transforms the FieldList object. - * @todo test for {@link FieldList->HiddenFields()}. Need to check - * the fields returned are the correct HiddenField objects for a - * given FieldList instance. - * @todo test for {@link FieldList->dataFields()}. - * @todo test for {@link FieldList->findOrMakeTab()}. - * @todo the same as above with insertBefore() and insertAfter() */ class FieldListTest extends SapphireTest { @@ -856,9 +845,6 @@ public function testInsertBeforeWithNestedCompositeFields() ); } - /** - * @todo check actual placement of fields - */ public function testInsertBeforeWithNestedTabsets() { $FieldListA = new FieldList( @@ -973,9 +959,6 @@ public function testInsertAfterWithNestedCompositeFields() ); } - /** - * @todo check actual placement of fields - */ public function testInsertAfterWithNestedTabsets() { $FieldListA = new FieldList( diff --git a/tests/php/Forms/GridField/GridFieldDetailFormTest/Category.php b/tests/php/Forms/GridField/GridFieldDetailFormTest/Category.php index c4a7c9f012f..77249e0cd2c 100644 --- a/tests/php/Forms/GridField/GridFieldDetailFormTest/Category.php +++ b/tests/php/Forms/GridField/GridFieldDetailFormTest/Category.php @@ -24,7 +24,6 @@ class Category extends DataObject implements TestOnly public function getCMSFields() { $fields = parent::getCMSFields(); - // TODO No longer necessary once FormScaffolder uses GridField $fields->replaceField( 'People', GridField::create( diff --git a/tests/php/Forms/GridField/GridFieldDetailFormTest/PeopleGroup.php b/tests/php/Forms/GridField/GridFieldDetailFormTest/PeopleGroup.php index f68da49189e..9530132e012 100644 --- a/tests/php/Forms/GridField/GridFieldDetailFormTest/PeopleGroup.php +++ b/tests/php/Forms/GridField/GridFieldDetailFormTest/PeopleGroup.php @@ -29,7 +29,6 @@ class PeopleGroup extends DataObject implements TestOnly public function getCMSFields() { $fields = parent::getCMSFields(); - // TODO No longer necessary once FormScaffolder uses GridField $fields->replaceField( 'People', GridField::create( diff --git a/tests/php/Forms/GridField/GridFieldDetailFormTest/Person.php b/tests/php/Forms/GridField/GridFieldDetailFormTest/Person.php index 9b76b3d2c23..2d4ac82c083 100644 --- a/tests/php/Forms/GridField/GridFieldDetailFormTest/Person.php +++ b/tests/php/Forms/GridField/GridFieldDetailFormTest/Person.php @@ -39,7 +39,6 @@ class Person extends DataObject implements TestOnly public function getCMSFields() { $fields = parent::getCMSFields(); - // TODO No longer necessary once FormScaffolder uses GridField $fields->replaceField( 'Categories', GridField::create( diff --git a/tests/php/Forms/GridField/GridFieldTest.php b/tests/php/Forms/GridField/GridFieldTest.php index 1b33db7599b..642460aa5ac 100644 --- a/tests/php/Forms/GridField/GridFieldTest.php +++ b/tests/php/Forms/GridField/GridFieldTest.php @@ -185,10 +185,6 @@ public function testGetStateData() { $obj = new GridField('testfield', 'testfield'); - // @todo - PHP 7.0.6 change requires __isset() to return true - // for each reference from left to right along an isset() invocation. - // See https://bugs.php.net/bug.php?id=62059 - // Check value persistence $this->assertEquals(15, $obj->State->NoValue(15)); $this->assertEquals(15, $obj->State->NoValue(-1)); diff --git a/tests/php/Forms/ListboxFieldTest.php b/tests/php/Forms/ListboxFieldTest.php index 8591164e771..085b0758fac 100644 --- a/tests/php/Forms/ListboxFieldTest.php +++ b/tests/php/Forms/ListboxFieldTest.php @@ -222,15 +222,6 @@ public function testValidationWithDataList() 'Field validates values in source map' ); - /** - * @todo re-enable these tests when field validation is removed from {@link ListboxField::setValue()} and moved - * to the {@link ListboxField::validate()} function - */ - // $field->setValue(4); - // $this->assertFalse( - // $field->validate($validator), - // 'Field does not validate values outside of source map' - // ); $field->setValue( false, new ArrayData( diff --git a/tests/php/Forms/NumericFieldTest.php b/tests/php/Forms/NumericFieldTest.php index f07a6dfc51c..567d9a436e1 100644 --- a/tests/php/Forms/NumericFieldTest.php +++ b/tests/php/Forms/NumericFieldTest.php @@ -128,9 +128,6 @@ public function testNumberTypeOnInputHtml() $field = new NumericField('Number'); $html = $field->Field(); - - // @todo - Revert to number one day when html5 number supports proper localisation - // See https://github.com/silverstripe/silverstripe-framework/pull/4565 $this->assertStringContainsString('type="text"', $html, 'number type not set'); } diff --git a/tests/php/Forms/RequiredFieldsTest.php b/tests/php/Forms/RequiredFieldsTest.php index cb9b9fa1cf0..f620a63c16e 100644 --- a/tests/php/Forms/RequiredFieldsTest.php +++ b/tests/php/Forms/RequiredFieldsTest.php @@ -5,9 +5,6 @@ use SilverStripe\Dev\SapphireTest; use SilverStripe\Forms\RequiredFields; -/** - * @todo Test the validation method php() - */ class RequiredFieldsTest extends SapphireTest { diff --git a/tests/php/Forms/TimeFieldTest.php b/tests/php/Forms/TimeFieldTest.php index 15359914405..54cc6f46529 100644 --- a/tests/php/Forms/TimeFieldTest.php +++ b/tests/php/Forms/TimeFieldTest.php @@ -59,7 +59,6 @@ public function testSetLocale() $f = new TimeField('Time', 'Time'); $f->setHTML5(false); $f->setLocale('fr_FR'); - // TODO Find an hour format that's actually different $f->setValue('23:59'); $this->assertEquals($f->dataValue(), '23:59:00'); } diff --git a/tests/php/ORM/DBFieldTest.php b/tests/php/ORM/DBFieldTest.php index 8168137b540..cb1cb0ae727 100644 --- a/tests/php/ORM/DBFieldTest.php +++ b/tests/php/ORM/DBFieldTest.php @@ -117,8 +117,6 @@ public function testPrepValueForDB() $this->assertEquals(true, $boolean->prepValueForDB(1)); $this->assertEquals(true, $boolean->prepValueForDB('1')); - // @todo - Revisit Varchar to evaluate correct behaviour of nullifyEmpty - /* Varchar behaviour: nullifyifEmpty defaults to true */ $varchar = DBVarchar::create(); $this->assertEquals(0, $varchar->prepValueForDB(0)); diff --git a/tests/php/ORM/DataObjectLazyLoadingTest.php b/tests/php/ORM/DataObjectLazyLoadingTest.php index 7581bc46ff6..ad2ed19aba0 100644 --- a/tests/php/ORM/DataObjectLazyLoadingTest.php +++ b/tests/php/ORM/DataObjectLazyLoadingTest.php @@ -95,8 +95,6 @@ public function testLazyLoadedFieldsHasField() $teams = DataObject::get(Team::class); // query parent class $subteam1Lazy = $teams->find('ID', $subteam1->ID); - // TODO Fix hasField() to exclude *_Lazy - // $this->assertFalse($subteam1Lazy->hasField('SubclassDatabaseField_Lazy')); $this->assertTrue($subteam1Lazy->hasField('SubclassDatabaseField')); } diff --git a/tests/php/ORM/DataObjectTest.php b/tests/php/ORM/DataObjectTest.php index 8d65c03db57..af99c2decc5 100644 --- a/tests/php/ORM/DataObjectTest.php +++ b/tests/php/ORM/DataObjectTest.php @@ -830,9 +830,6 @@ public function testHasOneAsField() $this->assertEquals($captain2->ID, $team1->Captain->ID); } - /** - * @todo Extend type change tests (e.g. '0'==NULL) - */ public function testChangedFields() { $obj = $this->objFromFixture(DataObjectTest\Player::class, 'captain1'); @@ -1140,9 +1137,6 @@ public function testFieldNamesThatMatchMethodNamesWork() ); } - /** - * @todo Re-enable all test cases for field existence after behaviour has been fixed - */ public function testFieldExistence() { $teamInstance = $this->objFromFixture(DataObjectTest\Team::class, 'team1'); @@ -1290,9 +1284,6 @@ public function testFieldExistence() ); } - /** - * @todo Re-enable all test cases for field inheritance aggregation after behaviour has been fixed - */ public function testFieldInheritance() { $schema = DataObject::getSchema(); @@ -1633,12 +1624,6 @@ public function testMerge() null, 'merge() with $overwriteWithEmpty overwrites empty fields on left object' ); - - // @todo test "left" priority flag - // @todo test includeRelations flag - // @todo test includeRelations in combination with overwriteWithEmpty - // @todo test has_one relations - // @todo test has_many and many_many relations } public function testPopulateDefaults() @@ -1919,7 +1904,6 @@ public function testManyManyExtraFields() public function testManyManyUnlimitedRowCount() { $player = $this->objFromFixture(DataObjectTest\Player::class, 'player2'); - // TODO: What's going on here? $this->assertEquals(2, $player->Teams()->dataQuery()->query()->unlimitedRowCount()); } diff --git a/tests/php/ORM/DataQueryTest.php b/tests/php/ORM/DataQueryTest.php index 7e3fa648008..c2b7342aa59 100644 --- a/tests/php/ORM/DataQueryTest.php +++ b/tests/php/ORM/DataQueryTest.php @@ -202,9 +202,6 @@ public function testConjunctiveGroup() ); } - /** - * @todo Test paramaterised - */ public function testNestedGroups() { $dq = new DataQuery(DataQueryTest\ObjectA::class); diff --git a/tests/php/ORM/ManyManyThroughListTest/PolyItem.php b/tests/php/ORM/ManyManyThroughListTest/PolyItem.php index 5afdd87c2f7..df5364ea768 100644 --- a/tests/php/ORM/ManyManyThroughListTest/PolyItem.php +++ b/tests/php/ORM/ManyManyThroughListTest/PolyItem.php @@ -21,7 +21,6 @@ class PolyItem extends DataObject implements TestOnly /** * Placeholder for missing belongs_many_many for polymorphic relation * - * @todo Make this work for belongs_many_many * @return Generator|DataObject[] */ public function Objects() diff --git a/tests/php/ORM/PolymorphicHasManyListTest.php b/tests/php/ORM/PolymorphicHasManyListTest.php index 916166cee10..e7211ef4bad 100644 --- a/tests/php/ORM/PolymorphicHasManyListTest.php +++ b/tests/php/ORM/PolymorphicHasManyListTest.php @@ -10,8 +10,6 @@ * Tests the PolymorphicHasManyList class * * @see PolymorphicHasManyList - * - * @todo Complete */ class PolymorphicHasManyListTest extends SapphireTest { diff --git a/tests/php/Security/MemberCsvBulkLoaderTest.php b/tests/php/Security/MemberCsvBulkLoaderTest.php index 723adcd46eb..e768f612537 100644 --- a/tests/php/Security/MemberCsvBulkLoaderTest.php +++ b/tests/php/Security/MemberCsvBulkLoaderTest.php @@ -104,7 +104,6 @@ public function testCleartextPasswordsAreHashedWithDefaultAlgo() DataObject::flush_and_destroy_cache(); $member = DataObject::get_by_id(Member::class, $memberID); - // TODO Direct getter doesn't work, wtf! $this->assertEquals(Security::config()->password_encryption_algorithm, $member->getField('PasswordEncryption')); $auth = new MemberAuthenticator(); $result = $auth->checkPassword($member, 'mypassword'); diff --git a/tests/php/Security/SecurityDefaultAdminTest.php b/tests/php/Security/SecurityDefaultAdminTest.php index 082e7895b90..034f4a68d13 100644 --- a/tests/php/Security/SecurityDefaultAdminTest.php +++ b/tests/php/Security/SecurityDefaultAdminTest.php @@ -21,8 +21,6 @@ protected function setUp(): void { parent::setUp(); - // TODO Workaround to force database clearing with no fixture present, - // and avoid sideeffects from other tests if (!static::$tempDB->isUsed()) { static::$tempDB->build(); } diff --git a/tests/php/View/RequirementsTest.php b/tests/php/View/RequirementsTest.php index 388927233a7..a16cfa8eb51 100644 --- a/tests/php/View/RequirementsTest.php +++ b/tests/php/View/RequirementsTest.php @@ -18,10 +18,6 @@ use SilverStripe\View\SSViewer; use SilverStripe\View\ThemeResourceLoader; -/** - * @todo Test that order of combine_files() is correct - * @todo Figure out how to clear the modified state of Requirements class - might affect other tests. - */ class RequirementsTest extends SapphireTest { diff --git a/tests/php/View/SSViewerTest.php b/tests/php/View/SSViewerTest.php index 487153e0290..ce91527f3d7 100644 --- a/tests/php/View/SSViewerTest.php +++ b/tests/php/View/SSViewerTest.php @@ -2057,7 +2057,6 @@ public function testProcessOnlyIncludesRequirementsOnce() public function testRequireCallInTemplateInclude() { - //TODO undo skip test on the event that templates ever obtain the ability to reference MODULE_DIR (or something to that effect) if (FRAMEWORK_DIR === 'framework') { $template = new SSViewer(['SSViewerTestProcess']);