St. Louis, US
Account created on 17 May 2019, over 5 years ago
#

Merge Requests

More

Recent comments

🇺🇸United States danflanagan8 St. Louis, US

I think both code review (the R in RTBC) and manual testing (the T in RTBC) need to be done by one or more people in the Community (the C in RTBC).

This is an old issue, too, so it would be great to turn the patch into an MR so that the tests can run (assuming the project is configured to run tests in Gitlab).

I'm no longer using this module and I don't have a lot of contribution time at the moment. I probably won't be able to offer too much support. The issue has 6 followers, though, so maybe it will get over the finish line yet!

Cheers!

🇺🇸United States danflanagan8 St. Louis, US

> does the current implementation avoid creating map and message tables?

Yes, the module provides an id_map plugin that extends the null plugin.

https://git.drupalcode.org/project/migrate_sandbox/-/blob/1.1.x/src/Plug...

It spits messages out with the Drupal messenger, but nothing goes to the db (he says as he proudly points at test coverage).

🇺🇸United States danflanagan8 St. Louis, US

Very interesting bug, @benjifisher. menu_link_parent is an odd duck. I never added demo configuration for this one. I wonder if that was because I tried and ran into this and gave up? More likely it looked like it wouldn't work in the sandbox and I never even tried to come up with a demo.

Making the process plugin itself configurable would (probably) allow things to work without failing.

How would we fix this withing Migrate Sandbox...

There is no migrate_sandbox migrate plugin. That's kind of by design in that this is trying to be very separate from everything else. But we're seeing that there are drawbacks to circumventing the plugin system a bit. We end up getting an executable without using the migration plugin manager. The funny business happens around here: https://git.drupalcode.org/project/migrate_sandbox/-/blob/1.1.x/src/Form...

One thing I could do is look at making this all cleaner.

But I'd bet we could add a very simple stubby migration plugin to the module and trick this process plugin into running without failing.

🇺🇸United States danflanagan8 St. Louis, US

Thanks for the clear reply, @stefan.korn. That scenario makes a lot of sense and seems like really good UX for the end user.

I'll assign this issue to myself to get some tests written.

🇺🇸United States danflanagan8 St. Louis, US

Hi, @stefan.korn. The MR looks really good. I really like the use of #states on the settings form. I would be happy to update the tests to cover this new feature.

Out of curiosity, would you describe the use case where setting force_download_filename was a requirement?

🇺🇸United States danflanagan8 St. Louis, US

I tested this and it works. I'm just going to merge and do a release.

🇺🇸United States danflanagan8 St. Louis, US

Ah dammit. I committed to the repo and not the issue fork. I reverted it. Trying again on the fork.

🇺🇸United States danflanagan8 St. Louis, US

I put in an MR. I made the category "viewfield" so that it doesn't get buried in the "reference" category.

🇺🇸United States danflanagan8 St. Louis, US

There was never a rector rule for this, AFAICT. I found a discussion in Slack, but I don't see anything in the rector issue queue.

https://drupal.slack.com/archives/C03L6441E1W/p1716293607661759

🇺🇸United States danflanagan8 St. Louis, US

Huh, when I run the test suite locally on D10.3 I indeed get these deprecation notices:

Remaining self deprecation notices (16)

9x: Using a translatable string as a category for field type is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. See https://www.drupal.org/node/3375748
1x in ViewfieldFormatterTest::testViewfieldFormatterDefault from Drupal\Tests\viewfield\FunctionalJavascript
1x in ViewfieldFormatterTest::testViewfieldFormatterTitle from Drupal\Tests\viewfield\FunctionalJavascript
1x in ViewfieldFormatterTest::testViewfieldFormatterRendered from Drupal\Tests\viewfield\FunctionalJavascript
1x in ViewfieldFormatterTest::testViewfieldArgumentHandling from Drupal\Tests\viewfield\FunctionalJavascript
1x in ViewfieldFormatterTest::testViewfieldItemsToDisplay from Drupal\Tests\viewfield\FunctionalJavascript

why don't I see those in Gitlab?

🇺🇸United States danflanagan8 St. Louis, US

I was wondering why the viewfield tests don't fail on D11. I think it's because this bug is only triggered when using field UI to add a field. In the tests, the fields are created programmatically. But then why do the same tests pass on D10? Shouldn't there be some kind of deprecation notice that pops up in D10? Or shouldn't there have been a rector rule for this change? This looks like a change we should have handled better as a community.

🇺🇸United States danflanagan8 St. Louis, US

I wonder if this has anything to do with recent changes to how field type categories work. See this change record: [#3375748].

What happens if you hack the viewfield module and change the field type category from @Translation('Reference') to "reference"?

Here's the line: https://git.drupalcode.org/project/viewfield/-/blob/8.x-3.x/src/Plugin/F...

🇺🇸United States danflanagan8 St. Louis, US

danflanagan8 changed the visibility of the branch 3488780-formatter-wsod to hidden.

🇺🇸United States danflanagan8 St. Louis, US

I created 🐛 ALA field formatter causes WSOD Active

I'm setting the status of this issue to Fixed since the MR has been committed. Let's focus on the new issue.

🇺🇸United States danflanagan8 St. Louis, US

Even a basic attempt at testing this code would have shown that is fails catastrophically.

The website encountered an unexpected error. Try again later.

TypeError: Drupal\ala\Plugin\Field\FieldFormatter\AdvancedLinkAttributesFieldFormatter::_construct(): Argument #1 ($token) must be of type Drupal\Core\Utility\Token, string given, called in /app/docroot/core/modules/link/src/Plugin/Field/FieldFormatter/LinkFormatter.php on line 40 in Drupal\ala\Plugin\Field\FieldFormatter\AdvancedLinkAttributesFieldFormatter->_construct() (line 50 of modules/contrib/ala/src/Plugin/Field/FieldFormatter/AdvancedLinkAttributesFieldFormatter.php).

The dev branch is currently unusable.

🇺🇸United States danflanagan8 St. Louis, US

There were a couple failures:

Layout Builder Blocks (Drupal\Tests\layout_builder\Functional\LayoutBuilderBlocks)

├ Behat\Mink\Exception\ResponseTextException: The text "Placeholder for the "The block label" block" appears in the text of this page, but it should not.

│ /builds/issue/drupal-3091671/vendor/behat/mink/src/WebAssert.php:907
│ /builds/issue/drupal-3091671/vendor/behat/mink/src/WebAssert.php:312
│ /builds/issue/drupal-3091671/core/modules/layout_builder/tests/src/Functional/LayoutBuilderBlocksTest.php:219

and

Drupal\Tests\views\Unit\Plugin\argument_validator\EntityTest 0 passes 1s 1 exceptions
FATAL Drupal\Tests\views\Unit\Plugin\argument_validator\EntityTest: test runner returned a non-zero error code (2).
Drupal\Tests\views\Unit\Plugin\argument_validator\EntityTest 0 passes 1 fails

🇺🇸United States danflanagan8 St. Louis, US

I added a fail test that exposes the bug. Now we just need to fix it!

🇺🇸United States danflanagan8 St. Louis, US

Great! I'm going to change this to a support request and mark it fixed so that we can get credit to @jonathan_hunt.

Cheers!

🇺🇸United States danflanagan8 St. Louis, US

The other issue is some protective code that's added to Views UI. I think that prevents a WSOD when editing a View in Views UI, and it may prevent saving a misconfigured View.

However, there are no update hooks or the like to fix existing Views configuration that has extra spaces. Nor would that issue fix any extra-space bugs that would be the result of a bad template or something like that.

And it sounds like that's where your problem crept in, right? Trailing spaces in twig (either in the View config or in the template)?

🇺🇸United States danflanagan8 St. Louis, US

If I'm understanding correctly, then there is no bug in the viewfield module. This module in no way allows configuration like "Output this field as a custom link". The way I see this is that when a misconfigured View is referenced by viewfield there can be trouble. But that's a problem with the View configuration, not a problem with viewfield.

Am I wrong? Should we close this as "Works as Designed"?

🇺🇸United States danflanagan8 St. Louis, US

I spun up umami with D10.3.8 and I'm not having any luck triggering the error. I made a content type with a viewfield and added a few of those nodes. Then I made a view of those nodes. I used [node:nid] as a argument for one of the viewfields. Still no errors.

While the txt file in #8 is non-unhelpful, it's only so useful since there are many other dependencies and I can't import that config.

I don't think there's anything I can do until there's either:

1. More of a backtrace with the error

or

2. Steps to reproduce starting with a new install

🇺🇸United States danflanagan8 St. Louis, US

Thanks for the report.

I just ran the tests on current and previous majors and unfortunately did not get any fails.

https://git.drupalcode.org/project/viewfield/-/pipelines/340030

Darn. Some fails would have helped.

🇺🇸United States danflanagan8 St. Louis, US

I created an upstream issue (I guess?) hoping for a new build script that generates a dist js.

https://github.com/CMSgov/hpt-validator/issues/62

🇺🇸United States danflanagan8 St. Louis, US

danflanagan8 made their first commit to this issue’s fork.

🇺🇸United States danflanagan8 St. Louis, US

Back to NW just to get that logo in an MR. Thanks!

🇺🇸United States danflanagan8 St. Louis, US

I think #11 looks great, @sourojeetpaul.

If you put that in an MR, I'll happily merge it. :)

🇺🇸United States danflanagan8 St. Louis, US

Hi @sourojeetpaul!

I really like this part of your new logo:

What if we make that the entire logo? That would look great at all sizes. It's also a good representation of the module, right? We're looking into the database and seeing the relationships.

I'm going to set back to NW, but I think we're really close to a good solution now!

🇺🇸United States danflanagan8 St. Louis, US

MR and patch both look good now!

🇺🇸United States danflanagan8 St. Louis, US

The patch looks good. I searched the 1.1.x branch for all occurrences of const string and there were exactly 8 of them. All are resolved in the patch.

One of them got missed on the MR though. Back to NW for that.

🇺🇸United States danflanagan8 St. Louis, US

My team just ran into this. It's not an issue on the 2.x release, luckily.

🇺🇸United States danflanagan8 St. Louis, US

I think you nailed it, @kristiaanvandeneynde:

I think this shows why we should have more classes in core marked as internal and/or final.

Agreed! I was kind of surprised wasn't internal.

Thanks for your comments to me and your work on the issue. Cheers!

🇺🇸United States danflanagan8 St. Louis, US

Thanks, @kristiaanvandeneynde.

Am I really allowed to pass four arguments to a constructor that accepts only 3 arguments? We were passing the EntityTypeManager as the fourth argument rather than relying on the already existing BC layer for that fourth argument (lots of work on this class lately!).

I'm still curious about removing a property from the class:

Beyond that, the `$cache` property is removed from PermissionsHashGenerator. Isn't that pretty big BC no-no kind of stuff?

My extension of PermissionsHashGenerator was using that property and therefore completely broke.

🇺🇸United States danflanagan8 St. Louis, US

What version of Drupal is this?

My understanding is that a translated string as a category is deprecated but shouldn't result in errors yet.

🇺🇸United States danflanagan8 St. Louis, US

I'm not sure why we're concerned about how gitlab renders it!

Because that's one of the essential uses of this logo! See the IS:

as well as on drupalcode.org as your project avatar

Thinking of it as an icon is a good idea in my opinion. Here are some effective examples:

Token:

Redirect:

Search API:

And here's one I created for a project I maintain:

The issue for that one shows that I made the misstep of making things too complicated at first as well. 📌 Project Browser: Create a logo for Crossword Fixed

We need to keep it simple.

🇺🇸United States danflanagan8 St. Louis, US

it also aligns with the module's functionality

I don't know that I agree with this. To me it looks like the logo is for a form builder or something like that. I don't have any great ideas, but I can't say I convinced this is a good choice. I showed another maintainer and he was skeptical as well.

I also think we should keep in mind that this logo doesn't seem to be rendered at 512px very often. On a project page it's 60px wide. And within entity browser it's more like 256px or something. This logo is not great at 60px:

🇺🇸United States danflanagan8 St. Louis, US

I put in an MR that uses #states to make the display id required when the view id is set. Maybe real validation would be better because #states requires JS, but seriously who is configuring this without JS enabled.

🇺🇸United States danflanagan8 St. Louis, US

danflanagan8 made their first commit to this issue’s fork.

🇺🇸United States danflanagan8 St. Louis, US

If we're being honest with ourselves, no one's going to review this. :(

I'm going to merge as is. It's based on some work we've used extensively on client projects and it has some basic test coverage and it's completely independent of other stuff, so it's not likely to muck any existing code up.

🇺🇸United States danflanagan8 St. Louis, US

Perfect! Without the fix the updated test fails with:

1) Drupal\Tests\viewfield\FunctionalJavascript\ViewfieldWidgetTest::testSelectWidget
Behat\Mink\Exception\ExpectationException: An option "block_disabled" exists in select "field_view_test[0][display_id]", but it should not.

With the fix it passes. The fix itself looks good to the eye as well. Let's merge.

Thanks!

🇺🇸United States danflanagan8 St. Louis, US

Thanks for the issue! I'm surprised this isn't a dupe, but I don't see any similar reports in the queue.

I added some test coverage to the MR. Let's see how that runs in Gitlab.

🇺🇸United States danflanagan8 St. Louis, US

danflanagan8 made their first commit to this issue’s fork.

🇺🇸United States danflanagan8 St. Louis, US

Ok, this is definitely a source plugin thing and can't be fixed using Migrate Conditions.

This might require a slightly modified data_parser plugin. I had a project not long ago where I made a modest extension of the Json data_parser to deal with Json that had a slightly different structure than what the Json parser expects:

/**
 * Obtain JSON data for migration...when the JSON response is super flat.
 *
 * @DataParser(
 *   id = "flat_json",
 *   title = @Translation("Flat JSON")
 * )
 */
class FlatJson extends Json {

  /**
   * The standard json parser expects the response to be an array of arrays.
   * This plugin handles a JSON response that is flat array, allowing the
   * response to be treated as a single row for the migration.
   *
   * {@inheritdoc}
   */
  protected function getSourceData(string $url): array {
    $response = $this->getDataFetcherPlugin()->getResponseContent($url);

    // Convert objects to associative arrays.
    $source_data = json_decode($response, TRUE, 512, JSON_THROW_ON_ERROR);

    // If json_decode() has returned NULL, it might be that the data isn't
    // valid utf8 - see http://php.net/manual/en/function.json-decode.php#86997.
    if (is_null($source_data)) {
      $utf8response = utf8_encode($response);
      $source_data = json_decode($utf8response, TRUE, 512, JSON_THROW_ON_ERROR);
    }

    return [$source_data];
  }

}

You might be able to do something similar where you introduce special handling for NULL data.

I'm going to close this issue since it's outside the realm of Migrate Conditions. The Drupal Slack #migration channel would be a great place to ask for additional help here. Good luck and happy migrating!

🇺🇸United States danflanagan8 St. Louis, US

Hi Ste,
I suspect this is something that would be better handled in your source plugin. What source plugin are you using? What is the error that you are seeing?

🇺🇸United States danflanagan8 St. Louis, US

I was fortunate enough to meet with the OS team at CMS and ask some questions about the validation stuff! What a nice group of devs.

First, there are no plans to create an api endpoint (security concerns and concerns over huge file sizes). Second, there are no plans to create a php library for validation (they want a single source of truth for validation, which is and will be the typescript library).

So what can we don with the npm package that has the validation as js?

The npm package is here: https://www.npmjs.com/package/hpt-validator

The github for that is here: https://github.com/CMSgov/hpt-validator

Naively, I want to make that npm package a dependency of the Drupal module. The module would then define a validation library that more-or-less is a drupal wrapper for the hpt-validator js. The validation would then happen on the front end, probably during file upload. Perhaps also on page load of the hpt edit form. And maybe after some use action (e.g. button click) on the hpt collection page.

I'm never sure what the current best practice is for js dependencies, though, so I need to research that.

🇺🇸United States danflanagan8 St. Louis, US

v2 info

🇺🇸United States danflanagan8 St. Louis, US

weight

🇺🇸United States danflanagan8 St. Louis, US

Contact fields

🇺🇸United States danflanagan8 St. Louis, US

cms-hpt update

🇺🇸United States danflanagan8 St. Louis, US

v2 settings form

🇺🇸United States danflanagan8 St. Louis, US

file clarification

🇺🇸United States danflanagan8 St. Louis, US

add links

🇺🇸United States danflanagan8 St. Louis, US

add explanation section

🇺🇸United States danflanagan8 St. Louis, US

fix images

🇺🇸United States danflanagan8 St. Louis, US

Added intro and example

🇺🇸United States danflanagan8 St. Louis, US

This broke a site where we extend PermissionsHashGenerator.

When calling parent::__construct($private_key, $cache, $static, $entity_type_manager); it goes WSOD because the PermissionsHashGenerator constructor got changed to accept three arguments instead of four. Beyond that, the `$cache` property is removed from PermissionsHashGenerator. Isn't that pretty big BC no-no kind of stuff?

I see there was a conversation about BC breaks (https://git.drupalcode.org/project/drupal/-/merge_requests/4494#note_284734) in contrib in at least on context, but I don't see any conversation around several other potential BC problems.

🇺🇸United States danflanagan8 St. Louis, US

Thanks for the heads-up, @rajeshreeputra!

I'll merge this and tag a new release. Cheers!

🇺🇸United States danflanagan8 St. Louis, US

Change step number

🇺🇸United States danflanagan8 St. Louis, US

Remove outdated step numbers

🇺🇸United States danflanagan8 St. Louis, US

I'm having fun and making lots of progress! I need to add tests. I also think I'm going to do this on a new 2.x branch because there are a huge number of updates and, though they aren't necessarily disruptive, I want people to pay attention and be careful during the update.

🇺🇸United States danflanagan8 St. Louis, US

Crediting @allie micka who conceived this and wrote the first version of what I'm about to post.

🇺🇸United States danflanagan8 St. Louis, US

We need this to be an MR before we move any further since we can't run tests on patches anymore.

🇺🇸United States danflanagan8 St. Louis, US

Thanks, @waspper. That looks correct. If you create an MR out of the patch, I'll merge it.

🇺🇸United States danflanagan8 St. Louis, US

D11 has been out for ages. Nothing new is going to come through. Closing.

🇺🇸United States danflanagan8 St. Louis, US

> Could be our view isn't getting cached in any case for some other reason.

Yeah, I was wondering myself why the tests didn't fail without this. The views in the test module all have caching configured correctly, from what I can tell. There's at least some chance that the presence of the "content type" filter on the View would result in the config:node_type_list cache tag getting added to the page. That's my best guess, but just a guess.

Thanks for making the change!

🇺🇸United States danflanagan8 St. Louis, US

That doc doesn't really describe this use of getCacheTags unfortunately. This is the usage where we're saying, "Cache the result of this until these tags are invalidated." If any node type has its configuration updated, it's possible that the list of micronode types has changed and so we can no longer trust the cached results of the filter.

🇺🇸United States danflanagan8 St. Louis, US

That MR looks correct to me, @justcaldwell.

I don't know if it's really legal for me to RTBC this. I guess I'm asserting that the MR contains the code I posted on the other issue and that you tested on the other issue.

🇺🇸United States danflanagan8 St. Louis, US

> All credit goes to @danflanagan8 for the fix.

Don't forget that I should also get all the credit for the regression!!!

🇺🇸United States danflanagan8 St. Louis, US

I updated the query method locally to query more like the bundle filter and I got the tests to pass:

  /**
   * {@inheritdoc}
   */
  public function query() {
    $this->ensureMyTable();
    $micronode_bundles = array_keys(micronode_get_node_types(TRUE));
    if ($this->value) {
      // Restrict to micronodes.
      if ($micronode_bundles) {
        $this->query->addWhere($this->options['group'], "$this->tableAlias.type", $micronode_bundles, 'IN');
      }
      else {
        // If there are no micronode bundles views should return nothing.
        // Modeled after Drupal\Core\Database\Query::alwaysFalse().
        $this->query->addWhereExpression($this->options['group'], '1 = 0');
      }
    }
    else {
      // Exclude micronodes.
      if ($micronode_bundles) {
        $this->query->addWhere($this->options['group'], "$this->tableAlias.type", $micronode_bundles, 'NOT IN');
      }
    }
  }

I'm trying to figure out the best way to push this up for a new MR.

🇺🇸United States danflanagan8 St. Louis, US

I'm no expert in SQL queries, but maybe the updated where clause leads to issues at scale?

Neither am I, though as I was making this change I did worry that "NOT LIKE" was going to be slower than "LIKE". I was hoping that worry was unfounded but perhaps I was right to be concerned.

Since I'm kind of nuts I had been thinking about how to rework this filter even before the comment from @justcaldwell. It occurred to me that it might make sense to copy off of whatever the normal node type filter does in the query. We'd do a call to micronode_get_micronode_types or whatever to get the content types we need to include. I'm not sure if xtending that filter makes sense, given all the extra configuration options and stuff that filter has. Maybe though.

🇺🇸United States danflanagan8 St. Louis, US

Yay! After some waiting for the old cached version to go away (I presume?), this looks really good!

Production build 0.71.5 2024